`
quxiaozuzhou
  • 浏览: 15612 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

Ajax与REST架构的简单示例

阅读更多
(本文于2010.10.01发表在《草根》杂志第四期,LAMP交流超级群(500人):106382633)
话说某日有见哥学社陈哥真人秀,在六体膜拜之后,鉴于之前也有看过REST的一些东东,于是便有了本文,正文如下:

REST(Representational State Transfer表述性状态转移)是一种体系架构,它为客户端和服务器之间的数据交互提供了指导。它将客户/服务器通信这种计算模型抽象到了Web层面。

REST最早是在Roy Thomas Fielding博士的博士论文中提出的,REST是一种针对网络应用的设计和开发方式,是一种风格,可以降低开发的复杂性,提高系统的可伸缩性。
REST强调如下的体系架构概念。
  1、网络上的所有事物都被抽象为资源(resource);
  2、每个资源对应一个唯一的资源标识(resource identifier),
  3、通过通用的连接器接口(generic connector interface)对资源进行操作;
  4、对资源的各种操作不会改变资源标识;
5、所有的操作都是无状态的(stateless)。

REST对于信息的核心抽象是资源,一个资源是一组实体的概念上的映射,而REST使用一个资源标识符来标识组件之间交互所涉及到的特定资源。REST连接器提供了访问和操作资源的值集合的一个通用接口。在这里所有的操作中,它们都是无状态的,这样就不必在多个请求之间保存状态,不必考虑上下文的约束,从而允许服务器组件迅速释放资源,并进一步简化其实现,从而提高系统的可伸缩性。

现在我们就一个简单的示例演示下REST。
在我们的示例中以Javascript为客户端,与HTTP服务器体系架构配合工作,使用URL作为资源标识,并将HTTP作为连接器接口。
客户端的代码:
    function rest() {
                var XMLHttpFactories = [
                    function () {return new XMLHttpRequest()},
                    function () {return new ActiveXObject("Msxml2.XMLHTTP")},
                    function () {return new ActiveXObject("Msxml3.XMLHTTP")},
                    function () {return new ActiveXObject("Microsoft.XMLHTTP")}
                ];

                var xmlhttp = false;
                for (var i = 0; i < XMLHttpFactories.length; i++) {
                    try {
                        xmlhttp = XMLHttpFactories[i]();
                    } catch (e) {
                        continue;
                    }
                    break;
                }
                // 建立XMLHttpRequest对象
                this.xmlhttp = xmlhttp;
            }

            rest.prototype._get = function(url, data) {
                var xmlhttp = this.xmlhttp;
                xmlhttp.open ('GET', url + "&" + data, false);
                xmlhttp.send (null);
                return xmlhttp.responseText;
            };

            rest.prototype._post = function(url, data) {
                var xmlhttp = this.xmlhttp;
                xmlhttp.open ('POST', url, false);
                xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
                xmlhttp.setRequestHeader ("Content-Length", data.length);
                xmlhttp.send (data);
                return xmlhttp.responseText;
            };

            rest.prototype.get = function(url, data) {
                url = url += "?op=GET";
                return this._get(url, data);
            }

            rest.prototype.post = function(url, data) {
                url = url += "?op=POST";
                return this._post(url, data);
            }

            rest.prototype.put = function(url, data) {
                url = url += "?op=PUT";
                return this._post(url, data);
            };

            rest.prototype.del = function(url, data) {
                url = url += "?op=DELETE";
                return this._get(url, data);
            };

            function t() {
                var restobj = new rest();

                document.write (restobj.get("http://localhost/test/service.php", "content=GET Content"));
                document.write (restobj.post("http://localhost/test/service.php", "content=POST Content"));
                document.write (restobj.put("http://localhost/test/service.php", "content=PUT Content"));
                document.write (restobj.del("http://localhost/test/service.php", "content=DELETE Content"));
            }

            t();

如上所示,我们在客户端创建XMLHttpRequest对象,并且通过这个对象实现通过HTTP对服务器的操作GET、PUT、POST和DELETE以检索和修改资源。HTTP则把对每一个资源的操作都限制在了4个之内:GET、POST、PUT和DELETE。HTTP的这四个方法分别对应我们常见的CRUD操作,具体对应关系如下 :

C(Create)         <==> POST
R(Read/Retrieve) <==> GET
U(Update)         <==> PUT
D(Delete/Destroy) <==> DELETE

虽然HTTP提供了这4个方法,但是在某些情况下,PUT和DELETE方法是不可用的,于是我们在这里使用GET方法和POST方法进行替代。另外,在JS操作时,需要注意同源策略(Same Origin Policy,SOP),考虑跨域的问题。
服务端代码:
<?php
/**
* REST后台程序简单示例
*/
class Resource {
    public function get($request) {
        echo 'content=', $request['content'], "; get resource Successful<br />";
    }

    public function post($request) {
        echo 'content=', $request['content'], "; post resource Successful<br />";
    }

    public function put($request) {
        echo 'content=', $request['content'], "; update resource Successful<br />";
    }

    public function delete($request) {
        echo 'content=', $request['content'], "; delete resource Successful<br />";
    }
}

$request = $_REQUEST;
$op = $request['op'];
$op = strtolower($op);

$ops = array(
    'get' => 1,
    'post' => 1,
    'put' => 1,
    'delete' => 1,
        );

if (!isset($ops[$op])) {
    die('input error!');
}

$resource = new Resource();
$resource->$op($request);


?>

如上所示,是我们提供REST数据的服务器端的代码。这里只是简单的应答请求,输出标识内容。

以上就是我们这个示例的全部了,在这个示例中,我们的整体架构是基于最简单的客户端/服务器模式,客户端使用Javascript,以Ajax实现。我们不需要使用PHP之类的语言生成客户端的页面,所有的客户端的工作都交给Javascript去做,包括从服务器端读取数据,生成页面内容,页面布局等等。在服务器端,我们需要做的是提供资源,针对客户端的请求返回对应的资源,此时的服务器是无状态的。客户与服务器之间的数据交换不依赖于服务器,由客户端来维护状态。

另外:REST只是一种体系架构风格,它并没有改变服务器,它改变的是我们的编码风格。
分享到:
评论

相关推荐

    Ajax and REST Recipes.pdf 高清下载

    1. Ajax与REST概念的重要性: 书籍《Ajax and REST Recipes: A Problem-Solution Approach》的核心内容是向读者展示如何使用下一代Ajax和REST技术实现Web网站上常见任务的解决方案。Ajax(Asynchronous JavaScript ...

    springboot+ajax示例

    SpringBoot与Ajax是现代Web开发中的两个重要技术,它们结合使用可以实现前后端的高效协作。SpringBoot简化了Spring框架的配置,提供了快速构建独立应用的能力,而Ajax则实现了页面的无刷新更新,提升了用户体验。 ...

    simple-crm-example:一个非常非常简单的 CRM 应用程序,使用 Java Spring Boot,JPA,使用 REST 架构构建。 一个简单的AJAX接口用于测试项目

    一个非常非常简单的 CRM 应用程序,使用 Java Spring Boot,JPA,使用 REST 架构构建。 一个简单的 AJAX 接口用于测试项目。 怎么跑 应用程序“fat”jar 位于目标文件夹内。 jar 包含运行应用程序所需的一切(嵌入式...

    jersey webapp ajax demo

    【标题】:“jersey webapp ajax demo”是一个展示如何在Java Web应用中使用Jersey框架与Ajax技术进行交互的示例项目。这个项目是通过Maven构建系统来管理依赖和构建流程的,使得开发者能够快速地搭建和测试RESTful...

    Zend_framework_in_REST

    REST架构的核心概念是**资源**,每个资源都有一个URI来唯一标识。文档中还提到了Roy Fielding提出的REST架构标准,他是HTTP协议的参与者之一,并在其2000年的博士论文中首次提出了REST的概念。 #### 八、RESTful ...

    struts2.1+ rest

    通过分析和运行这个示例项目,开发者可以深入理解Struts2.1框架如何与RESTful服务结合,以及如何在实际项目中应用这种架构。同时,这也为初学者提供了一个很好的学习平台,让他们能够亲手实践并掌握相关技术。

    apirest示例:APIREST [PHP,MySql,Jquery,Ajax0]的实现

    APIREST是一种基于HTTP协议设计的软件架构风格,用于构建RESTful API。REST(Representational State Transfer,表述性状态转移)是一种网络应用程序的设计风格和开发方式,强调资源的概念,并通过URI(统一资源...

    spring-boot-ajax:如何使用Jquery和Ajax调用rest API

    在现代Web应用开发中,Spring Boot与Ajax的结合使用能够实现前后端的高效通信,提供更流畅的用户体验。本文将详细讲解如何在Spring Boot项目中使用Jquery和Ajax调用RESTful API,以实现无刷新的数据更新。 首先,...

    API-REST:AJAX的API REST服务

    4. **分层系统**:REST架构允许中间层(如代理服务器或负载均衡器)存在,这些中间层可以透明地处理请求,而不会影响客户端和服务器之间的交互。 5. **统一接口**:REST接口遵循HTTP方法的语义,如GET用于获取资源...

    AJAX-JQ-REST

    以下是一个简单的示例,展示如何使用jQuery的AJAX功能与REST API进行通信: ```javascript $.ajax({ url: 'http://api.example.com/data', type: 'GET', dataType: 'json', success: function(response) { // ...

    Beginning ASP.NET 2.0 AJAX.pdf

    - **第一个ASP.NET AJAX应用**:通过一个简单的示例来展示如何创建一个基本的ASP.NET AJAX应用程序。 - **关键概念**:解释了异步请求、局部刷新等AJAX开发中的重要概念。 #### 4. ASP.NET AJAX架构 (Chapter 3) - ...

    demo-autocomplete:一个简单的spring boot autocomplete ajax rest

    【标题】"demo-autocomplete:一个简单的spring boot autocomplete ajax rest" 涉及到的关键技术是Spring Boot、Ajax以及RESTful API的实现,用于创建一个自动完成的功能。这个项目提供了一个基本的框架,展示了如何...

    ext示例提供自己研究

    在这样的架构中,EXTJS作为用户界面层,负责展示数据、处理用户交互,并通过AJAX请求与RESTEasy服务通信。RESTEasy则在服务器端处理这些请求,进行业务逻辑处理和数据操作,然后将结果以JSON或其他格式返回给EXTJS...

    ajax_start.pdf

    #### 四、Ajax与架构设计 在实际项目开发中,合理的架构设计对于Ajax的成功应用至关重要。这包括但不限于: - **前后端分离**:将前端展示逻辑与后端数据处理逻辑分离,使得前端可以独立于后端进行开发和测试。 - ...

    利用PHP、REST、Dojo开发敏捷的Web_2.0应用

    文件"2.BPS_利用PHP、REST、Dojo开发敏捷的Web 2.0应用.ppt"可能是关于这个主题的详细讲解,可能包含了如何将这三种技术结合使用以构建Web 2.0应用的具体步骤、最佳实践和示例。另一份文件"1.Blue Power Station ...

    基于springMVC3.2的REST源码,结合了jquery和json

    REST(Representational State Transfer)是一种架构风格,用于设计网络应用程序,强调资源的识别和状态的转移。在RESTful服务中,每个URL代表一个资源,HTTP方法(GET、POST、PUT、DELETE等)则用于操作这些资源。 ...

    api-rest-ajax

    在"api-rest-ajax-master"这个项目中,我们可以推测这是一个关于使用AJAX技术与RESTful API交互的示例或教程。开发者可能通过JavaScript编写客户端代码,利用AJAX调用RESTful API,从而实现动态、异步的数据获取和...

    HKwest.js:HKwest.js是一个简单JavaScript AJAX和HTTPREST请求库

    HKwest.js是一个轻量级的JavaScript库,专为简化AJAX(Asynchronous JavaScript and XML)和HTTP REST(Representational State Transfer)请求而设计。在Web开发中,AJAX技术允许前端与服务器进行异步通信,无需...

Global site tag (gtag.js) - Google Analytics