加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-15 21:33:26 所属栏目:百科 来源:网络整理
导读:注意:以下代码请在Firefox 3.5、Chrome 3.0、Safari 4之后的版本中进行测试。IE8的实现方法与其他浏览不同。 跨域请求,顾名思义,就是一个站点中的资源去访问另外一个不同域名站点上的资源。这种情况很常见,比如说通过 style 标签加载外部样式表文件、通

注意:以下代码请在Firefox 3.5、Chrome 3.0、Safari 4之后的版本中进行测试。IE8的实现方法与其他浏览不同。

跨域请求,顾名思义,就是一个站点中的资源去访问另外一个不同域名站点上的资源。这种情况很常见,比如说通过 style 标签加载外部样式表文件、通过 img 标签加载外部图片、通过 script 标签加载外部脚本文件、通过 Webfont 加载字体文件等等。默认情况下,脚本访问文档属性等数据采用的是同源策略(Same origin policy)。

那么,什么是同源策略呢?如果两个页面的协议、域名和端口是完全相同的,那么它们就是同源的。同源策略是为了防止从一个地址加载的文档或脚本访问或者设置从另外一个地址加载的文档的属性。如果两个页面的主域名相同,则还可以通过设置 document.domain 属性将它们认为是同源的。

随着 Web2.0 和 SNS 的兴起,Web 应用对跨域访问的需求也越来越多,但是,在脚本中进行跨域请求是受安全性限制的,Web 开发人员迫切需要提供一种更安全、方便的跨域请求方式来融合(Mashup)自己的 Web 应用。这样做的一个好处就是可以将请求分摊到不同的服务器,减轻单个服务器压力以提高响应速度;另外一个好处是可以将不同的业务逻辑分布到不同的服务器上以降低负载。

值得庆幸的是,跨域请求的标准已经出台,主流浏览器也已经实现了这一标准。W3C 工作组中的 Web Applications Working Group(Web 应用工作组)发布了一个 Cross-Origin Resource Sharing(跨域资源共享,该规范地址:http://www.w3.org/TR/access-control/和http://dev.w3.org/2006/waf/access-control/) 推荐规范来解决跨域请求的问题。该规范提供了一种更安全的跨域数据交换方法。具体规范的介绍可以访问上面提供的网站地址。值得注意的是:该规范只能应用在类似 XMLHttprequest 这样的 API 容器内。IE8、Firefox 3.5 及其以后的版本、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-www-form-urlencoded、multipart/form-data 或者 text/plain中一个。
b,HTTP 请求没有设置自定义的请求头,如我们常用的 X-JSON。

先使用下面的代码进行测试:

[xhtml] view plain copy
  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='开始测试'onclick='crossDomainRequest()'/>
  9. <divid="content"></div>
  10. <mce:scripttype="text/<ahref="http://lib.csdn.net/base/18"class='replace_word'title="JavaScript知识库"target='_blank'style='color:#df3434;font-weight:bold;'>JavaScript</a>"><!--
  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. }
  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 的内容如下:

[xhtml] view plain copy
  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>

点击 “开始测试” 按钮,发送的请求和返回的响应信息如下:

[xhtml] view plain copy
  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
  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;path=/;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 源下的脚本才可以进行访问。

好了,上面我们就完成了一个简单的跨域请求,怎么样?感觉还是不错的吧。下面我们进行一个“预检”请求。


注意:以下代码请在Firefox 3.5、Chrome 3.0、Safari 4之后的版本中进行测试。IE8的实现方法与其他浏览不同。

2,预检请求

预检请求首先需要向另外一个域名的资源发送一个 HTTP OPTIONS 请求头,其目的就是为了判断实际发送的请求是否是安全的。下面的2种情况需要进行预检:
a,不是上面的简单请求,比如使用Content-Type 为 application/xml 或 text/xml 的 POST 请求
b,在请求中设置自定义头,比如 X-JSON、X-MENGXIANHUI 等

注意:在 iis 里进行测试,必须在“应用程序扩展”里面配置 .aspx 扩展的动作允许 OPTIONS。

下面我们举一个预检的请求:

[xhtml] view plain copy
  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='开始测试'onclick='crossDomainRequest()'/>
  9. <divid="content"></div>
  10. <mce:scripttype="text/<ahref="http://lib.csdn.net/base/18"class='replace_word'title="JavaScript知识库"target='_blank'style='color:#df3434;font-weight:bold;'>JavaScript</a>"><!--
  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',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="不能创建XMLHttpRequest。";
  24. }
  25. }
  26. functionhandler(evtXHR){
  27. if(xhr.readyState==4){
  28. if(xhr.status==200){
  29. varresponse=xhr.responseText;
  30. document.getElementById("content").innerHTML="结果:"+response;
  31. }else{
  32. document.getElementById("content").innerHTML="不能进行跨越访问。";
  33. }
  34. }
  35. else{
  36. document.getElementById("content").innerHTML+="<br/>执行状态readyState:"+xhr.readyState;
  37. }
  38. }
  39. //--></mce:script>
  40. </body>
  41. </html>

上面的例子我们发送 xml 格式的数据,并且,发送一个非标准的HTTP头 POWERED-BY-MENGXIANHUI 来说明服务器端该如何设置响应头的。

在服务器端,PreflightedRequests.aspx 的内容如下:

[xhtml] view plain copy
  1. <%@PageLanguage="C#"%>
  2. <mce:scriptrunat="server"><!--
  3. protectedvoidPage_Load(objectsender,EventArgse)
  4. {
  5. if(Request.HttpMethod.Equals("GET"))
  6. {
  7. Response.Write("这个页面是用来测试跨域POST请求的,直接浏览意义不大。");
  8. }
  9. elseif(Request.HttpMethod.Equals("OPTIONS"))
  10. {
  11. //通知客户端允许预检请求。并设置缓存时间
  12. Response.ClearContent();
  13. Response.AddHeader("Access-Control-Allow-Origin","http://www.meng_xian_hui.com:801");
  14. Response.AddHeader("Access-Control-Allow-Methods","POST,GET,OPTIONS");
  15. Response.AddHeader("Access-Control-Allow-Headers","POWERED-BY-MENGXIANHUI");
  16. Response.AddHeader("Access-Control-Max-Age","30");
  17. //此过程无需返回数据
  18. Response.End();
  19. }
  20. elseif(Request.HttpMethod.Equals("POST"))
  21. {
  22. if(Request.Headers["Origin"].Equals("http://www.meng_xian_hui.com:801"))
  23. {
  24. System.Xml.XmlDocumentdoc=newSystem.Xml.XmlDocument();
  25. doc.Load(Request.InputStream);
  26. Response.AddHeader("Access-Control-Allow-Origin","http://www.meng_xian_hui.com:801");
  27. Response.Write("您提交的数据是:<br/><br/>"+Server.HtmlEncode(doc.OuterXml));
  28. }
  29. else
  30. {
  31. Response.Write("不允许你的网站请求。");
  32. }
  33. }
  34. }
  35. //--></mce:script>

点击“开始测试”按钮,将会执行下面的一系列请求。

[xhtml] view plain copy
  1. OPTIONS/PreflightedRequests.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,*;q=0.7
  5. Keep-Alive:300
  6. Connection:keep-alive
  7. Origin:http://www.meng_xian_hui.com:801
  8. Access-Control-Request-Method:POST
  9. Access-Control-Request-Headers:powered-by-mengxianhui
  10. HTTP/1.x200OK
  11. Date:Sun,10Jan201014:00:34GMT
  12. Server:Microsoft-IIS/6.0
  13. X-Powered-By:ASP.NET
  14. X-AspNet-Version:2.0.50727
  15. Access-Control-Allow-Origin:http://www.meng_xian_hui.com:801
  16. Access-Control-Allow-Methods:POST,OPTIONS
  17. Access-Control-Allow-Headers:POWERED-BY-MENGXIANHUI
  18. Access-Control-Max-Age:30
  19. Set-Cookie:ASP.NET_SessionId=5npqri55dl1k1zvij1tlw3re;path=/;HttpOnly
  20. Cache-Control:private
  21. Content-Length:0
  22. POST/PreflightedRequests.aspxHTTP/1.1
  23. Host:dotnet.aspx.cc
  24. User-Agent:Mozilla/5.0(Windows;U;WindowsNT5.2;zh-CN;rv:1.9.1.7)Gecko/20091221Firefox/3.5.7(.NETCLR3.5.30729)
  25. Accept:text/html,*;q=0.7
  26. Keep-Alive:300
  27. Connection:keep-alive
  28. POWERED-BY-MENGXIANHUI:Approve
  29. Content-Type:application/xml;charset=UTF-8
  30. Referer:http://www.meng_xian_hui.com:801/CrossDomainAjax/PreflightedRequests.html
  31. Content-Length:19
  32. Origin:http://www.meng_xian_hui.com:801
  33. Pragma:no-cache
  34. Cache-Control:no-cache
  35. <root>测试</root>
  36. HTTP/1.x200OK
  37. Date:Sun,10Jan201014:00:34GMT
  38. Server:Microsoft-IIS/6.0
  39. X-Powered-By:ASP.NET
  40. X-AspNet-Version:2.0.50727
  41. Access-Control-Allow-Origin:http://www.meng_xian_hui.com:801
  42. Set-Cookie:ASP.NET_SessionId=byvose45zmtbqy45d2a1jf2i;path=/;HttpOnly
  43. Cache-Control:private
  44. Content-Type:text/html;charset=utf-8
  45. Content-Length:65

以上的代码反映了预检请求的执行过程:首先发送 OPTIONS 请求头,用来向服务器咨询服务器的更多信息,以便为后续的真实请求做准备。比如是否支持 POST 方法等。值得注意的是:

浏览器还发送 Access-Control-Request-Method: POST 和 Access-Control-Request-Headers: powered-by-mengxianhui 请求头。

注意:以上过程是第一次请求的时候的过程,如果在 30 秒内重复点击按钮,你可以看不到 OPTIONS 这一过程。则执行过程是这样的:

[xhtml] view plain copy
  1. POST/PreflightedRequests.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,10Jan201014:06:32GMT
  5. Server:Microsoft-IIS/6.0
  6. X-Powered-By:ASP.NET
  7. X-AspNet-Version:2.0.50727
  8. Access-Control-Allow-Origin:http://www.meng_xian_hui.com:801
  9. Set-Cookie:ASP.NET_SessionId=qs1c4urxywdbdx55u04pvual;path=/;HttpOnly
  10. Cache-Control:private
  11. Content-Type:text/html;charset=utf-8
  12. Content-Length:65

为什么会这样?细心的童鞋可能注意到了,在服务器端有一行代码 Response.AddHeader("Access-Control-Max-Age","30"); 它是用来设置预检的有效时间的,单位是秒。这一点要特别注意。


注意:以下代码请在Firefox 3.5、Chrome 3.0、Safari 4之后的版本中进行测试。IE8的实现方法与其他浏览不同。

3,带验证信息的请求

身份验证是Web开发中经常遇到的问题,在跨域请求中,默认情况下是不发送验证信息的。要想发送验证信息,需要进行withCredentials 属性,下面就是一个简单请求的例子:

[xhtml] view plain copy
  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='开始测试'onclick='crossDomainRequest()'/>
  9. <divid="content"></div>
  10. <mce:scripttype="text/<ahref="http://lib.csdn.net/base/18"class='replace_word'title="JavaScript知识库"target='_blank'style='color:#df3434;font-weight:bold;'>JavaScript</a>"><!--
  11. varxhr=newXMLHttpRequest();
  12. varurl='http://dotnet.aspx.cc/RequestsWithCredentials.aspx';
  13. functioncrossDomainRequest(){
  14. document.getElementById("content").innerHTML="开始进行请求……";
  15. if(xhr){
  16. xhr.open('GET',true);
  17. xhr.onreadystatechange=handler;
  18. xhr.withCredentials="true";
  19. xhr.send();
  20. }else{
  21. document.getElementById("content").innerHTML="不能创建XMLHttpRequest。";
  22. }
  23. }
  24. functionhandler(evtXHR){
  25. if(xhr.readyState==4){
  26. if(xhr.status==200){
  27. varresponse=xhr.responseText;
  28. document.getElementById("content").innerHTML="结果:"+response;
  29. }else{
  30. document.getElementById("content").innerHTML+="<br/>执行状态status:"+xhr.status;
  31. }
  32. }
  33. else{
  34. document.getElementById("content").innerHTML+="<br/>执行状态readyState:"+xhr.readyState;
  35. }
  36. }
  37. //--></mce:script>
  38. </body>
  39. </html>

点击“开始测试”,我们可以检测到下面的请求执行过程:

[xhtml] view plain copy
  1. GET/RequestsWithCredentials.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,*;q=0.7
  5. Keep-Alive:300
  6. Connection:keep-alive
  7. Referer:http://www.meng_xian_hui.com:801/CrossDomainAjax/RequestsWithCredentials.html
  8. Origin:http://www.meng_xian_hui.com:801
  9. HTTP/1.x200OK
  10. Date:Sun,10Jan201014:12:26GMT
  11. Server:Microsoft-IIS/6.0
  12. X-Powered-By:ASP.NET
  13. X-AspNet-Version:2.0.50727
  14. Access-Control-Allow-Origin:http://www.meng_xian_hui.com:801
  15. Access-Control-Allow-Credentials:true
  16. Set-Cookie:ASP.NET_SessionId=fn2zf0zq1cuwgf45fm5fw145;path=/;HttpOnly
  17. Set-Cookie:visit=1;expires=Sun,10-Jan-201014:12:56GMT;path=/
  18. Cache-Control:no-cache
  19. Pragma:no-cache
  20. Expires:-1
  21. Content-Type:text/html;charset=utf-8
  22. Content-Length:1

从上面的响应中可以看出,Cookie 是会随请求一起发送的。如果我们多次点击测试按钮,则可以看到请求和响应的结果是这样的:

[xhtml] view plain copy
  1. GET/RequestsWithCredentials.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,*;q=0.7
  5. Keep-Alive:300
  6. Connection:keep-alive
  7. Referer:http://www.meng_xian_hui.com:801/CrossDomainAjax/RequestsWithCredentials.html
  8. Origin:http://www.meng_xian_hui.com:801
  9. Cookie:ASP.NET_SessionId=fn2zf0zq1cuwgf45fm5fw145;visit=2
  10. HTTP/1.x200OK
  11. Date:Sun,10Jan201014:13:58GMT
  12. Server:Microsoft-IIS/6.0
  13. X-Powered-By:ASP.NET
  14. X-AspNet-Version:2.0.50727
  15. Access-Control-Allow-Origin:http://www.meng_xian_hui.com:801
  16. Access-Control-Allow-Credentials:true
  17. Set-Cookie:visit=3;expires=Sun,10-Jan-201014:14:28GMT;path=/
  18. Cache-Control:no-cache
  19. Pragma:no-cache
  20. Expires:-1
  21. Content-Type:text/html;charset=utf-8
  22. Content-Length:1

注意 Cookie: ASP.NET_SessionId=fn2zf0zq1cuwgf45fm5fw145; visit=2 这一行,访问计数器已经被一起发送到服务器。

4,IE8 中的实现方法

IE8已经开始支持跨域访问资源了,但是,IE8提供的功能还比较简单,可以进行简单的请求,下面是一个使用的例子:

[xhtml] view plain copy
  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='开始测试'onclick='crossDomainRequest()'/>
  9. <divid="content"></div>
  10. <mce:scripttype="text/javascript"><!--
  11. varxhr=newXDomainRequest();
  12. varurl='http://dotnet.aspx.cc/SimpleCrossSiteRequests.aspx';
  13. functioncrossDomainRequest(){
  14. document.getElementById("content").innerHTML="开始……";
  15. if(xhr){
  16. xhr.open('GET',url);
  17. xhr.onload=handler;
  18. xhr.send();
  19. }else{
  20. document.getElementById("content").innerHTML="不能创建XDomainRequest";
  21. }
  22. }
  23. functionhandler(evtXHR){
  24. document.getElementById("content").innerHTML="结果:"+xhr.responseText;
  25. }
  26. //--></mce:script>
  27. </body>
  28. </html>

另外,IE8的实现方法与其他浏览器不同。更多内容请参考 XDomainRequest 对象,地址是:
http://msdn.microsoft.com/zh-cn/library/cc288060(VS.85).aspx

最后,愿意测试的朋友可以访问这个 http://dotnet.aspx.cc/SimpleCrossSiteRequests.aspx 地址进行“简单请求”的测试,本页面允许任何地址进行跨域访问。(不好意思,个人网站可能被河蟹了)


来自:

http://www.52php.cn/article/p-rhpwlcah-kp.html

http://www.52php.cn/article/p-qvnywmsm-kp.html

http://www.52php.cn/article/p-zusieemx-kp.html

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读