1 / 12
文档名称:

AJAX(XMLHttpRequest)进行跨域请求方法详解.doc

格式:doc   大小:45KB   页数:12页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

AJAX(XMLHttpRequest)进行跨域请求方法详解.doc

上传人:9nrng26 2017/5/14 文件大小:45 KB

下载得到文件列表

AJAX(XMLHttpRequest)进行跨域请求方法详解.doc

文档介绍

文档介绍:发表于:2010-1-11 浏览:965 作者:转载遗失来源:网络转载关键字:AJAX, 详解,请求描述:注意:以下代码请在 、 、 Safari4 之后的版本中进行测试。 IE8 的实现方法与其他浏览不同。跨域请求,顾名思义,就是一个站点中的资源去访问另外一个不同域名站点上的资源。这种情况很常见注意:以下代码请在 Firefox 、 Chrome 、 Safari 4之后的版本中进行测试。 IE8 的实现方法与其他浏览不同。跨域请求,顾名思义,就是一个站点中的资源去访问另外一个不同域名站点上的资源。这种情况很常见, 比如说通过 style 标签加载外部样式表文件、通过 img 标签加载外部图片、通过 script 标签加载外部脚本文件、通过 Webfont 加载字体文件等等。默认情况下,脚本访问文档属性等数据采用的是同源策略( Same origin policy )。那么,什么是同源策略呢?如果两个页面的协议、域名和端口是完全相同的,那么它们就是同源的。同源策略是为了防止从一个地址加载的文档或脚本访问或者设置从另外一个地址加载的文档的属性。如果两个页面的主域名相同,则还可以通过设置 属性将它们认为是同源的。随着 和 SNS 的兴起, Web 应用对跨域访问的需求也越来越多,但是,在脚本中进行跨域请求是受安全性限制的, Web 开发人员迫切需要提供一种更安全、方便的跨域请求方式来融合( Mashup ) 自己的 Web 应用。这样做的一个好处就是可以将请求分摊到不同的服务器,减轻单个服务器压力以提高响应速度;另外一个好处是可以将不同的业务逻辑分布到不同的服务器上以降低负载。值得庆幸的是,跨域请求的标准已经出台,主流浏览器也已经实现了这一标准。 W3C 工作组中的 Web Applications Working Group ( Web 应用工作组)发布了一个 Cross-Origin Resource Sharing (跨域资源共享,该规范地址: /access-control/ 和 http://dev./2006/waf/access-control/ )推荐规范来解决跨域请求的问题。该规范提供了一种更安全的跨域数据交换方法。具体规范的介绍可以访问上面提供的网站地址。值得注意的是:该规范只能应用在类似 XMLHttprequest 这样的 API 容器内。 IE8 、 Firefox 及其以后的版本、 Chrome 浏览器、 Safari 4等已经实现了 Cross-Origin Resource Sharing 规范,已经可以进行跨域请求了。 Cross-Origin Resource Sharing 的工作方式是通过添加 HTTP 头的方法来判断哪些资源允许 Web 浏览器访问该域名下的信息。然而,对于那些 HTTP 请求导致用户数据产生副作用的请求方法(特别是对于除了 GET 、某些 MIME 类型的 POST 之外的 HTTP 方法),该规范要求浏览器对请求进行“预先验”, 通过发送 HTTP 的 OPTIONS 请求头询问服务器有哪些支持的方法,在征得服务器的同意后,再使用实际的 HTTP 请求方法发送实际的请求。服务器也可以通知客户端是否需要将验证信息(如 Cookie 和 HTTP Authentication 数据)随同请求一起发送。下面我们就采用实际的例子说明 Cross-Origin Resource Sharing 是如何工作的。 1,简单请求什么样的请求算是简单请求呢?简单请求必须满足下面 2点: a,只使用 GET 、 POST 进行的请求,这里的 POST 只包括发送给服务器的数据类型( Content-Type ) 必须是 application/x-ded 、 multipart/form-data 或者 text/plain 中一个。 b, HTTP 请求没有设置自定义的请求头,如我们常用的 X-JSON 。先使用下面的代码进行测试: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML Transitional//EN" "/xhtml1/DTD/xhtml1-"> <html xmlns="9/xhtml"> <head> <title> 孟宪会之 AJAX 跨域请求测试</title> </head> <body> <input type= ‘ button ‘ value= ‘开始测试‘ onclick= ‘ crossDomainRequest() ‘/> <div id="content"></di