没有合适的资源?快使用搜索试试~ 我知道了~
首页JS跨域访问解决方案的总结.doc
JS跨域访问解决方案的总结.doc
2星 需积分: 12 10 下载量 183 浏览量
更新于2023-03-16
评论
收藏 203KB DOC 举报
JS跨域访问解决方案的总结.doc跨域请求,顾名思义,就是一个站点中的资源去访问另外一个不同域名站点上的资源。这种情况很常见,比如说通过style标签加载外部样式表文件、通过 img 标签加载外部图片、通过 script 标签加载外部脚本文件、通过 Web font 加载字体文件等等。默认情况下,脚本访问文档属性等数据采用的是同源策略(Same origin policy)。
资源详情
资源评论
资源推荐
JS 跨域访问解决方案总结
0 引言:
跨域请求,顾名思义,就是一个站点中的资源去访问另外一个不同域名站点上的资
源。这种情况很常见,比如说通过 style 标签加载外部样式表文件、通过 img 标
签加载外部图片、通过 script 标签加载外部脚本文件、通过 Web font 加载字体
文件等等。默认情况下,脚本访问文档属性等数据采用的是同源策略(Same
origin policy)。
同源策略:如果两个页面的协议、域名和端口是完全相同的,那么它们就是同源的。
同源策略是为了防止从一个地址加载的文档或脚本访问或者设置从另外一个地址加
载的文档的属性。如果两个页面的主域名相同,则还可以通过设置
document.domain 属性将它们认为是同源的。
随着 Web2.0 和 SNS 的兴起,Web 应用对跨域访问的需求也越来越多,但在脚
本中进行跨域请求是受安全性限制的,Web 开发人员迫切需要提供一种更安全、
方便的跨域请求方式来融合(Mashup)自己的 Web 应用。这样做的一个好处就
是可以将请求分摊到不同的服务器,减轻单个服务器压力以提高响应速度;另外一
个好处是可以将不同的业务逻辑分布到不同的服务器上以降低负载。
值得庆幸的是,跨域请求的标准已经出台,主流浏览器也已经实现了这一标准。
W3C 工作组中的 Web Applications Working Group(Web 应用工作组)发布
了一个 Cross-Origin Resource Sharing(跨域资源共享规范)推荐规范来
解决跨域请求的问题。该规范提供了一种更安全的跨域数据交换方法。具体规范的
介绍可以访问上面提供的网站地址。值得注意的是:该规范只能应用在类似
XMLHttprequest 这样的 API 容器内。IE8、Firefox 3.5 及其以后的版本、
Chrome 浏览器、Safari 4 等已经实现了 Cross-Origin Resource Sharing 规
范,已经可以进行跨域请求了。
一、支持跨域访问处理浏览器
Cross-Origin Resource Sharing 的工作方式是通过添加 HTTP 头的方法来判断
哪些资源允许 Web 浏览器访问该域名下的信息。然而,对于那些 HTTP 请求导致
用户数据产生副作用的请求方法(特别是对于除了 GET、某些 MIME 类型的
POST 之外的 HTTP 方法),该规范要求浏览器对请求进行“预先验”,通过发送
1
HTTP 的 OPTIONS 请求头询问服务器有哪些支持的方法,在征得服务器的同意后,
再使用实际的 HTTP 请求方法发送实际的请求。服务器也可以通知客户端是否需
要将验证信息(如 Cookie 和 HTTP Authentication 数据)随同请求一起发送。
下面我们就采用实际的例子说明 Cross-Origin Resource Sharing 是如何工作的。
1,简单请求
什么样的请求算是简单请求呢?简单请求必须满足下面 2 点:
a,只使用 GET、POST 进行的请求,这里的 POST 只包括发送给服务器的数据类
型(Content-Type)必须是 application/x-www-form-
urlencoded、multipart/form-data 或者 text/plain 中一个。
b,HTTP 请求没有设置自定义的请求头,如我们常用的 X-JSON。
先使用下面的代码进行测试:
XML/HTML 代码
1. <!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"
2. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd>
3. <htmlxmlns="http://www.w3.org/1999/xhtml">
4. <head>
5. <title>孟宪会之 AJAX 跨域请求测试</title>
6. </head>
7. <body>
8. <inputtype='button'value='开始测试'onclic
k='crossDomainRequest()'/>
9. <divid="content"></div>
10. <mce:scripttype="text/javascript"><!--
11. varxhr=newXMLHttpRequest();
12. varurl='http://dotnet.aspx.cc/
SimpleCrossSiteRequests.aspx';
13. functioncrossDomainRequest(){
14. document.getElementById("content").innerHTML="开始……";
15. if(xhr){
16. xhr.open('GET',url,true);
17. xhr.onreadystatechange=handler;
18. xhr.send();
19. }else{
20. document.getElementById("content").innerHTML="不能创
建 XMLHttpRequest";
21. }
22. }
2
23. functionhandler(evtXHR){
24. if(xhr.readyState==4){
25. if(xhr.status==200){
26. varresponse=xhr.responseText;
27. document.getElementById("content").innerHTML="结
果:"+response;
28. }else{
29. document.getElementById("content").innerHTML="不允
许跨域请求。";
30. }
31. }
32. else{
33. document.getElementById("content").innerHTML+="<br/>
执行状态 readyState:"+xhr.readyState;
34. }
35. }
36. //--></mce:script>
37. </body>
38. </html>
然后,在服务器创建 CrossDomainRequest.aspx 的内容如下:
C# 代码
1. <%@PageLanguage="C#"%>
2. <mce:scriptrunat="server"><!--
3. protectedvoidPage_Load(objectsender,EventArgse)
4. {
5. Response.AddHeader("Access-Control-Allow-Origin","http://
www.meng_xian_hui.com:801");
6. Response.Write("孟宪会向各位朋友发来贺电:你的第一个跨域测试成功
啦!!!");
7. }
8. //--></mce:script>
点击 “开始测试” 按钮,发送的请求和返回的响应信息如下:
XML/HTML 代码
1. GET/SimpleCrossSiteRequests.aspxHTTP/1.1
2. Host:dotnet.aspx.cc
3. User-Agent:Mozilla/5.0(Windows;U;WindowsNT5.2;zh-CN;rv:
1.9.1.7)Gecko/20091221Firefox/3.5.7(.NETCLR3.5.30729)
4. Accept:text/html,application/xhtml+xml,application/
xml;q=0.9,*/*;q=0.8
5. Accept-Language:zh-cn,zh;q=0.5
6. Accept-Encoding:gzip,deflate
3
7. Accept-Charset:GB2312,utf-8;q=0.7,*;q=0.7
8. Keep-Alive:300
9. Connection:keep-alive
10. Referer:http://www.meng_xian_hui.com:801/CrossDomainAjax/
SimpleCrossSiteRequests.html
11. Origin:http://www.meng_xian_hui.com:801
12. HTTP/1.x200OK
13. Date:Sun,10Jan201013:52:00GMT
14. Server:Microsoft-IIS/6.0
15. X-Powered-By:ASP.NET
16. X-AspNet-Version:2.0.50727
17. Access-Control-Allow-Origin:http://www.meng_xian_hui.com:801
18. Set-Cookie:ASP.NET_SessionId=wk5v5nrs5wbfi4rmpjy2jujb;pat
h=/;HttpOnly
19. Cache-Control:private
20. Content-Type:text/html;charset=utf-8
21. Content-Length:84
需要特别注意的是:在请求信息中,浏览器使用 Origin 这个 HTTP 头来标识该请
求来自于 http://www.meng_xian_hui.com:801;在返回的响应信息中,使用
Access-Control-Allow-Origin 头来控制哪些域名的脚本可以访问该资源。如果
设置 Access-Control-Allow-Origin:*,则允许所有域名的脚本访问该资源。如果
有多个,则只需要使用逗号分隔开即可。
注意:在服务器端,Access-Control-Allow-Origin 响应头
http://www.meng_xian_hui.com:801 中的端口信息不能省略。
有人可能会想:自己发送请求头会如何呢?比如
xhr.setRequestHeader("Origin","http://www.meng_xian_hui.com:801");
实践证明,自己设置 Origin 头是不行的。
是不是现在就可以采用 XMLHttpRequest 来请求任意一个网站的数据呢?还是不
行的。允许哪些域名可以访问,还需要服务器来设置 Access-Control-Allow-
Origin 头来进行授权,具体的代码是:
Response.AddHeader("Access-Control-Allow-Origin",
"http://www.meng_xian_hui.com:801");
这行代码就告诉浏览器,只有来自 http://www.meng_xian_hui.com:801 源下
的脚本才可以进行访问。
好了,上面我们就完成了一个简单的跨域请求,怎么样?感觉还是不错的吧。下面
我们进行一个“预检”请求。
2,预检请求
预检请求首先需要向另外一个域名的资源发送一个 HTTP OPTIONS 请求头,其目
的就是为了判断实际发送的请求是否是安全的。下面的 2 种情况需要进行预检:
a,不是上面的简单请求,比如使用 Content-Type 为 application/xml 或 text/xml 的
4
POST 请求
b,在请求中设置自定义头,比如 X-JSON、X-MENGXIANHUI 等
注意:在 iis 里进行测试,必须在“应用程序扩展”里面配置 .aspx 扩展的动作允许
OPTIONS。
下面我们举一个预检的请求:
XML/HTML 代码
1. <!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"
2. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3. <htmlxmlns="http://www.w3.org/1999/xhtml">
4. <head>
5. <title>孟宪会之 AJAX 跨域请求测试</title>
6. </head>
7. <body>
8. <inputtype='button'value='开始测试'onclic
k='crossDomainRequest()'/>
9. <divid="content"></div>
10. <mce:scripttype="text/javascript"><!--
11. varxhr=newXMLHttpRequest();
12. varurl='http://dotnet.aspx.cc/PreflightedRequests.aspx';
13. functioncrossDomainRequest(){
14. document.getElementById("content").innerHTML="开始进行请求
……";
15. if(xhr){
16. varxml="<root>测试</root>";
17. xhr.open('POST',url,true);
18. xhr.setRequestHeader("POWERED-BY-MENGXIANHUI","Approve"
);
19. xhr.setRequestHeader("Content-Type","application/xml");
20. xhr.onreadystatechange=handler;
21. xhr.send(xml);
22. }else{
23. document.getElementById("content").innerHTML="不能创建 XM
LHttpRequest。";
24. }
25. }
26. functionhandler(evtXHR){
27. if(xhr.readyState==4){
28. if(xhr.status==200){
29. varresponse=xhr.responseText;
5
剩余23页未读,继续阅读
zdzyh1989
- 粉丝: 0
- 资源: 1
上传资源 快速赚钱
- 我的内容管理 收起
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
会员权益专享
最新资源
- ExcelVBA中的Range和Cells用法说明.pdf
- 基于单片机的电梯控制模型设计.doc
- 主成分分析和因子分析.pptx
- 共享笔记服务系统论文.doc
- 基于数据治理体系的数据中台实践分享.pptx
- 变压器的铭牌和额定值.pptx
- 计算机网络课程设计报告--用winsock设计Ping应用程序.doc
- 高电压技术课件:第03章 液体和固体介质的电气特性.pdf
- Oracle商务智能精华介绍.pptx
- 基于单片机的输液滴速控制系统设计文档.doc
- dw考试题 5套.pdf
- 学生档案管理系统详细设计说明书.doc
- 操作系统PPT课件.pptx
- 智慧路边停车管理系统方案.pptx
- 【企业内控系列】企业内部控制之人力资源管理控制(17页).doc
- 温度传感器分类与特点.pptx
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论2