`

AngularJS与服务器交互

阅读更多

        对于AJAX应用(使用XMLHttpRequests)来说,向服务器发起请求的传统方式是:获取一个XMLHttpRequest对象的引用、发起请求、读取响应、检查状态码,最后处理服务端的响应。整个过程示例如下:

var xmlhttp = new XMLHttpRequest();

xmlhttp.onreadystatechange = function() {
    if(xmlhttp.readystate == 4 && xmlhttp.status == 200) {
        var response = xmlhttp.responseText;
    }else if(xmlhttp.status == 400) { //或者可以是任何以4开头的状态码
        //优雅地处理错误
    }
};

//建立连接
xmlhttp.open("GET", "http://myserver/api", true);

//发起请求
xmlhttp.send();

        对于简单、常用而且会经常重复的任务来说,这是一种很烦琐的工作。如果你想复用以上过程,你应该进行封装或者使用代码库。

        AngularJS XHR API遵守一种通常被称为Promise的接口。由于XHR是异步调用的方法,所以服务端的响应会在未来某个不确定的时间点上返回(我们希望它立即能返回)。Promise接口规定了处理这种响应的方式,并且允许Promise的使用者以一种可预见的方式来使用它。

        例如,我们要从服务端获取一个用户的信息,假设用来接受请求的后台接口位于/api/user路径上,此接口可以接受一个id属性作为URL参数,那么使用Angular的核心$http服务发起XHR请求的方法示例如下:

$http.get('api/user', {params: {id:'5'}
}).success(function(data, status, headers, config) {
    //加载成功之后做一些事
}).error(function(data, status, headers, config) {
    //处理错误
});

        如果你是jQuery使用者,你应该会发现,AngularJS和jQuery在对异步请求的处理方面非常类似。

        上面例子中使用的$http.get方法是AngularJS的核心服务$http所提供的众多快捷方法之一。类似地,如果你想使用AngularJS向同一个URL发送POST请求,同时带上一些POST数据,你可以像下面这样做:

var postData = {text:'long blob of text'};
//下面这一行会被当成参数附加到URL后面,所以post请求最终会变成/api/user?id=5
var config = {params: {id: '5'}};
$http.post('api/user', postData, config
).success(function(data, status, headers, config) {
    //成功之后做一些事情
}).error(function(data, status, headers, config) {
    //处理错误
});

        对于大多数常用的请求类型,都有类似的快捷方法,这些请求类型包括:GET、HEAD、POST、DELETE、PUT、JSONP。

一.进一步配置请求

        虽然标准的请求方式使用起来比较简单,但是,有时候会存在可配置性不佳的缺点。如果你想要实现下面这些事情就会遇到困难:

        a.给请求加上一些授权头。

        b.修改对缓存的处理方式。

        c.用一些特殊的方式来变换发送出去的请求,或者变换接收到的响应。

        在这些情况下,你可以给请求传递一个可选的配置对象,从而对请求进行深度配置。在前面的例子中,我们使用config对象指定了一个可选的URL参数。但是那里的GET和POST方法是一些快捷方式。这种深度简化之后的方法调用示例如下:

$http(config)

        下面是一个基本的伪代码模板,用来调用前面的这个方法:

$http({
   method: string,
   url: string,
   params: object,
   data: string or object,
   headers: object,
   transformRequest: function transform(data, headersGetter) or an array of functions,
   transformResponse: function transform(data, headersGetter) or an array of functions,
   cache: boolean or Cache object,
   timeout: number,
   withCredentials: boolean
});

        GET、POST及其他快捷方法都会自动设置method参数,所以不需要手动设置。config对象会作为最后一个参数传递给$http.get和$http.post,所以,在所有的快捷方法内部都可以使用这个参数。你可以传递config对象来修改发送的请求,config对象可以设置以下键值。

        method:一个字符串,表示HTTP请求的类型,例如GET或者POST。

        url:URL字符串,表示请求的绝对或者相对资源路径。

        params:一个键和值都是字符串的对象(确切来说是一个map),表示需要转换成URL参数的键和值。例如:

[{key1: 'value1', key2: 'value2'}]

        将会被转换成

?key1=value&key2=value2

        并会被附加到URL后面。如果我们使用js对象(而不是字符串或者数值)作为map中的值,那么这个js对象会被转换成JSON字符串。

        data:一个字符串或者对象,它会被当作请求数据发送。

        timeout:在请求超时之前需要等待的毫秒数。

 

二.设置HTTP头

        AngularJS带有一些默认的请求头,Angular发出的所有请求上都会带有这些默认的请求头信息。默认请求头包括以下两个:

        1.Accept:appliction/json,text/pain,/

        2.X-Requested-With: XMLHttpRequest

        如果想设置特殊的请求头,可以用如下两种方法实现。

        第一种方法,如果你想把请求头设置到每一个发送出去的请求上,那么你可以把需要使用的特殊请求头设置成AngularJS的默认值。这些值可以通过$httpProvider.defaults.headers配置对象来设置,通常会在应用的配置部分来做这件事情。所以,如果你想对所有的GET请求使用“DO NOT TRACK"头,同时对所有请求删除Requested-With头,可以简单地操作如下:

angular.module('MyApp', []).
    config(function($httpProvider) {
        //删除AngularJS默认的X-Request-With头
        delete $httpProvider.default.headers.common['X-Requested-With'];
        //为所有GET请求设置DO NOT TRACK
        $httpProvider.default.headers.get['DNT'] = '1';
});

        如果你只想对某些特定的请求设置请求头,但不把它们作为默认值,那么你可以把头信息作为配置对象的一部分传递给$http服务。同样的,自定义头信息也可以作为第二个参数的一部分传递给GET请求,第二个参数还可以同时接受URL参数。

$http.get('api/user', {
     //设置Authorization(授权)头。在真实的应用中,你需要到一个服务里面去获取auth令牌
     headers: {'Authorization': 'Basic Qzsda231231'},
     params: {id:5}
}).success(function() {//处理成功的情况 });

 

三.缓存响应

        对于HTTP GET请求,AngularJS提供了一个开箱即用的简单缓存机制。默认情况下它对所有请求类型都不可用,为了启用缓存,你需要做一些配置:

$http.get('http://server/myapi', {
    cache: true
}).success(function() {//处理成功的情况});

        这样就可以启用缓存,然后AngularJS将会缓存来自服务器的响应。下一次向同一个URL发送请求的时候,AngularJS将会返回缓存中的响应内容。缓存也是智能的,所以即使你向同一个URL发送多次模拟的请求,缓存也只会向服务器发送一个请求,而且在收到服务端的响应之后,响应的内容会被分发给所有请求。

        但是,这样做有些不太实用,因为用户会先看到缓存的旧结果,然后看到新的结果突然出现。例如,当用户即将点击一条数据时,它可能会突然发生变化。

        注意,从本质上来说,响应(即使是从缓存中读取的)依然是异步的。换句话说,在第一次发出请求的时候,你应该使用处理异步请求的方式来编码。

 

四.转换请求和响应

        对于所有通过$http服务发出的请求和收到的响应来说,AngularJS都会进行一些基本的转换,包括如下内容。

1.转换请求

        如果请求的配置对象属性中包含JS对象,那么就把这个对象序列化成JSON格式。

2.转换响应

        如果检测到了XSRF(Cross Site Request Forgery的缩写,意为跨站请求伪造,这是跨站脚本攻击的一种方式)前缀,则直接丢弃。如果检测到了JSON响应,则使用JSON解析器对它进行反序列化。

        如果你不需要其中的某些转换,或者想自已进行转换,可以在配置项里面传入自已的函数。这些函数会获取HTTP的request/response体以及协议头信息,然后输出序列化、修改之后的版本。可以使用transformLRequest和transformResponse作为key来配置这些转换函数,而这两个函数在模块的config函数中是用$httpProvider服务来配置的。

        我们什么时候需要使用这些东西呢?假设我们有一个服务,它更适合用jQuery的方式来操作。POST数据使用key1=val1&key2=val2(也就是字符串)形式来代替{key1:val1, key2:val2}JSON格式。我们可以在每个请求中来进行这种转换,也可以添加一个独立transformRequest调用,对于当前这个例子来说,我们打算添加一个通用的transformRequest,这样所有发出的请求都会进行这种从JSON到字符串的转换。下面就是实现方式:

var module = angular.module('myApp');

module.config(function($httpProvider) {
    $httpProvider.defaults.transformRequest = function(data) {
          //使用jQuery的param方法把JSON数据转换成字符串形式
          return $.param(data);
     };
});

 

文章来源:《用AngularJS开发下一代Web应用》

分享到:
评论

相关推荐

    AngularJS与服务器交互前端和后端代码

    **AngularJS 与服务器交互** AngularJS 是一个强大的前端JavaScript框架,主要用于构建单页应用程序(SPA)。它提供了双向数据绑定、依赖注入、模块化和MVC(Model-View-Controller)架构模式,使得前端开发更加...

    AngularJs与web服务器交互

    在AngularJS中,与Web服务器交互主要依赖于其内置的`$http`服务。`$http`服务提供了与HTTP协议兼容的方法,如GET、POST、PUT、DELETE等,用于向服务器发送请求并接收响应。它使用Promise API来处理异步操作,使得...

    angularjs实现与服务器交互分享

    ### AngularJS实现与服务器交互详解 #### 一、引言 在现代Web开发中,客户端与服务器之间的交互是必不可少的一部分。对于大多数应用而言,无论是为了将数据存储在云端,还是为了实现实时通信功能,都需要应用程序...

    AngularJS实现与后台服务器进行交互的示例讲解

    在AngularJS中,与后台服务器进行交互是应用开发的关键部分,允许前端获取和发送数据,以实现动态内容的展示和用户交互。本文将详细介绍如何在AngularJS中使用$http服务来实现这一目标。 首先,AngularJS的Model和...

    angularJS之$http:与服务器交互示例

    $http服务是AngularJS提供的用于与远程HTTP服务器进行通信的核心服务,它封装了浏览器原生的XMLHttpRequest对象,使得开发者可以更方便地通过AJAX与服务器进行数据交互。 $http服务支持多种HTTP请求方法,如GET、...

    AngularJS实现与Java Web服务器交互操作示例【附demo源码下载】

    本文实例讲述了AngularJS实现与Java Web服务器交互操作的方法。分享给大家供大家参考,具体如下: AngularJS是Google工程师研发的产品,它的强大之处不是几句话就能描述的,只有真正使用过的人才能体会到,笔者准备...

    angularJS理论与实战.ppt

    3. HTTP交互:使用$http服务进行Ajax请求,与服务器进行数据交互。 4. 路由配置:使用uirouter配置路由,实现页面间的动态加载和导航。 5. 自定义指令:根据需求创建自定义指令,增强DOM元素的功能。 四、最佳实践 ...

    AngularJS+ NodeJS

    2. **前后端分离**:AngularJS处理前端交互,Node.js作为API服务器,提供RESTful接口。 3. **数据流**:AngularJS通过$http服务向Node.js发送Ajax请求,Node.js处理数据并返回。 4. **安全实践**:如JWT(JSON Web ...

    angularJs权威和精通angularjs

    服务是AngularJS中的单例对象,它们负责执行特定任务,如$http用于与服务器通信,$location用于处理URL,$q用于异步编程等。 **7. Routing:** AngularJS的路由功能使得在单页面应用中导航变得简单,通过uirouter或...

    AngularJS与后端php的数据交互方法

    AngularJS与后端PHP的数据交互是Web开发中的关键环节,特别是在构建动态、数据驱动的Web应用程序时。AngularJS,一个由Google支持的前端JavaScript框架,以其强大的MVC架构、双向数据绑定和模块化设计而闻名。而PHP...

    AngularJS入门教程之与服务器(Ajax)交互操作示例【附完整demo源码下载】

    本文实例讲述了AngularJS与服务器Ajax交互操作。分享给大家供大家参考,具体如下: AngularJS从Web服务器请求资源都是通过Ajax来完成,所有的操作封装在$http服务中,$http服务是只能接收一个参数的函数,这个参数是...

    AngularJS学习 chm 文件

    4. **服务**:AngularJS 提供了一系列内置服务,如$http服务用于与服务器通信,$q服务用于异步编程,$rootScope服务代表应用的全局作用域等。此外,开发者也可以自定义服务来满足特定需求。 5. **过滤器**:过滤器...

    AngularJS+springmvc的demo

    5. **JSON序列化与反序列化**: SpringMVC 可以通过`Jackson`库自动处理JSON数据的转换,方便与AngularJS进行交互。 6. **安全控制**: Spring Security 可以集成到SpringMVC中,提供认证和授权功能,保护应用资源。 ...

    angularjs管理系统框架

    4. **服务**:AngularJS 的服务是一种可注入的对象,可以用来封装和共享代码,如 $http 服务用于与服务器通信,$rootScope 服务则是应用范围内的全局作用域。 5. **依赖注入**:AngularJS 的依赖注入机制简化了组件...

    AngularJS 中文API参考手册

    5. 服务(Service):AngularJS的服务提供了一种方式来共享代码和状态,比如$http服务用于与服务器通信,$rootScope全局作用域服务等。 6. 指令(Directives):指令是AngularJS的自定义HTML标签或属性,用于扩展...

Global site tag (gtag.js) - Google Analytics