Ajax跨子域

简介: 主页index.html的主要代码如下: 开始跨域 document.domain = '2fool.cn'; function crossDomain(){ var iframe=document.

主页index.html的主要代码如下:

<button onclick="crossDomain();">开始跨域</button>
<div id="ajax"></div>
<iframe src="http://work.2fool.cn/crossdomain/iframe.html" id="iframe" style="display:none;">
</iframe>
<script type="text/javascript">
document.domain = '2fool.cn';
function crossDomain(){
    var iframe=document.getElementById('iframe').contentWindow.$;        
    iframe.get("http://work.2fool.cn/crossdomain/helloworld.txt",function(data){
        document.getElementById("ajax").innerHTML=data;
    });
}
</script>

iframe页面主要代码如下:

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
<script type="text/javascript">
document.domain = '2fool.cn';
</script> 

原理:通过给主页面跟请求页面设置相同的document.domain来,欺骗浏览器,达到Ajax跨子域的效果,此方法在IE,chrome,Firefox,Safari,Opera下测试通过。

缺点:无法实现不同主域名之间的通讯。并且当在一个页面中还包含有其它的iframe时,会产生安全性异常,拒绝访问。

img_fa0be433d68c8212b2b0b3b1a564ccb1.png
如果本文对你有所帮助,请打赏——1元就足够感动我:)
支付宝打赏 微信打赏
联系邮箱:intdb@qq.com
我的GitHub: https://github.com/vipstone
关注公众号: img_9bde0f31ac4a0eca10b1bd7414b78faf.png


作者: 王磊
出处: http://vipstone.cnblogs.com/
本文版权归作者和博客园共有,欢迎转载,请标明出处。

相关文章
|
11月前
|
前端开发 uml
如何管理庞大的Ajax请求?
如何管理庞大的Ajax请求?
46 0
|
移动开发 安全 JavaScript
html5使用postMessage解决跨域和跨窗口消息传递的解决方案
html5使用postMessage解决跨域和跨窗口消息传递的解决方案
141 0
|
前端开发 JavaScript C#
【C#编程最佳实践 十】控件使用及Ajax通信
【C#编程最佳实践 十】控件使用及Ajax通信
78 0
|
Web App开发 移动开发 安全
「趣学前端」关于iframe跨域通信
用技术实现梦想,用梦想打开创意之门。之前开发遇到了iframe跨域通信的问题,今天分享一下解决方案,顺便总结一波知识点。
904 1
「趣学前端」关于iframe跨域通信
|
XML JSON 前端开发
完善 myAjax 方法达到能获取同源数据和非同源数据| 学习笔记
快速学习完善 myAjax 方法达到能获取同源数据和非同源数据。
107 0
|
缓存 移动开发 前端开发
浏览器专题系列 - 跨域与跨站(二)
浏览器专题系列 - 跨域与跨站(二)
|
存储 前端开发 JavaScript
浏览器专题系列 - 跨域与跨站(一)
浏览器专题系列 - 跨域与跨站(一)
|
JSON 前端开发 API
前端 ajax 请求的优雅方案
前端 ajax 请求的优雅方案
108 0
|
JavaScript 前端开发 中间件
前端人员都懂的浏览器的同源策略,以及如何进行不同源间的相互访问
作为前端开发人员,你要是连同源策略都不知道是什么,那就太说不过去了。本篇文章将讲述同源策略的定义, 以及当我们需要克服同源策略,如何进行跨域访问数据的方法。
283 0
前端人员都懂的浏览器的同源策略,以及如何进行不同源间的相互访问
|
前端开发
express搭建后端请求路由,前端进行访问对应的接口 后端解决跨域
express搭建后端请求路由,前端进行访问对应的接口 后端解决跨域