`

Ajax与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只是一种体系架构风格,它并没有改变服务器,它改变的是我们的编码风格。

[转自 :http://www.phppan.com/2010/10/ajax-rest/ ]

 

分享到:
评论

相关推荐

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

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

    Asp.Net及相关技术介绍

    1.三种Web服务主流架构的历史演变与示例。(XML-RPC,SOAP,REST) 2. REST兴起与Asp.Net WebAPI介绍。 3. Asp.Net WebAPI与相关技术比较及SOA 。 4. 与WebAPI配合的前端JS开发框架介绍(Knockout与jQuery)。

    java二进制补码源码-DubboxDemo:dubbox的介绍和简单示例

    ##Dubbo架构 Provider: 暴露服务的服务提供方。 Consumer: 调用远程服务的服务消费方。 Registry: 服务注册与发现的注册中心。 Monitor: 统计服务的调用次调和调用时间的监控中心。 Container: 服务运行容器。 ##为...

    web-downsizing-paper-sample:该示例项目显示了具有更多客户端运行功能的Web软件体系结构。 在此项目中,有服务器端服务

    就Web架构,HTTP,URI,REST,HTML5,CSS3,JavaScript和Ajax进行了简短的讨论,作为在客户端上处理该架构的基础。 除了描述之外,还提出了它的结构,操作以及它的优点和缺点,而不是在这项工作中穷尽。 最后,给出...

    todo-api-with-json-schema:带有 json 模式验证的示例 todo API

    todo-api-with-json-schema ...当夹具对象与架构不匹配时的示例错误消息 拉姆达 如果您使用或可以用咖喱架构工具函数来创建简洁的功能对象的验证和消毒名单。 有关示例,请参阅cypress/integration/ui-sp

    crud-operation-in-react-js-and-mysql:react.js 和 mysql 中的 CRUD 操作

    教程:React Node.js MySQL CRUD 示例——分步 React、Nodejs 和 Mysql 简单的全栈应用 在本教程中,我将通过分步编码示例介绍如何借助 Ajax 构建“React.js Nodejs CRUD MySQL Example”项目到 POST/GET/PUT/DELETE...

    redux-api:用于redux基础结构的Flux REST API

    Redux-api 用于Redux基础架构的Flux REST API介绍redux-api解决了编写客户端与后端通信的问题。 它生成用于对API端点进行AJAX调用的和器。 如果您使用redux并想与服务器交换数据,则无需编写很多。 受启发,旨在与...

    Struts 2.1 权威指南 part13 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

    Struts 2.1 权威指南 part04 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

    Struts 2.1 权威指南 part01 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

    Struts 2.1 权威指南 part02 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

    Struts 2.1 权威指南 part06 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

    Struts 2.1 权威指南 part03 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

    Struts 2.1 权威指南 part05 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

    Struts 2.1 权威指南 part11 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

    Struts 2.1 权威指南 part12 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

    Struts 2.1 权威指南 part10 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

    Struts 2.1 权威指南 part09 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

    Struts 2.1 权威指南 part07 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

    Struts 2.1 权威指南 part08 pdf

    笔者在介绍Struts 2.1框架时,既照顾到了Struts 2.1初学者的能力,对每个知识点都给出简单的快速上手的示例;同时也考虑到开发者在日后开发中可能遇到的问题,详细讲解了每个知识点的各种用法,本书覆盖了Struts 2.1...

Global site tag (gtag.js) - Google Analytics