首页 > 开发 > AJAX > 正文

基于iframe实现ajax跨域请求 获取网页中ajax数据

2024-09-01 08:28:09
字体:
来源:转载
供稿:网友

大家都知道,在不同域的情况下是不能发送ajax请求的,浏览器会报如下错误:

同时,内嵌的iframe中无法进行跨域通信的,也就是说不同域的iframe是无法互相读取数据的(当然利用hash变化可以从父window传入数据到子iframe,不过并没有什么意义)。iframe跨域通信时,浏览器会报如下错误:

其实这两个问题都是由于跨域造成的。

下面就介绍如何解决这个问题。

其实问题的关键就在于,浏览器在解析ajax请求地址时会和当前网页的地址进行比较,如果是跨域的,那就禁止掉并且报错。那么我们如果让浏览器解析出的ajax地址和当前网页的解析地址一样,浏览器不就不会禁止我们的请求了么。

那么浏览器是如何解析url的呢?

首先当浏览器访问一个域名时,会查询本地的DNS缓存中是否有关于这个网址对应ip地址,如果有的话,直接从本地取得ip地址然后访问,如果没有,浏览器就会向DNS服务器发出DNS请求获得该域名对应的ip地址然后存入本地缓存然后访问。

那么介于以上问题,我们只要在本地伪造一条域名的解析方式,然后再通过伪造的域和目标域进行跨域请求不就可以了么。

windows下的打开C:/Windows/System32/drivers/etc
这个文件夹下有一个hosts文件,如果改过hosts来上谷歌的同学对这个应该很熟悉,在hosts文件里加上这样一段代码:

127.0.0.1         a.目标网址.com

这样你的访问a.目标网址.com就和访问localhost一样了,这样做的目的是方便搭起本地的服务时,本地的服务和目标的域名之间就不会存在跨域问题了,这样就能在本地,通过在目标网页植入iframe标签的方式,向目标域发起跨域请求,取得目标域的数据。

直接上代码(用了jQuery)

脚本代码,直接插在父域

var mySrc = "http://a.目标网址.com:9000/myIframe.html";document.domain = "目标网址.com";  //关键代码,将域提升到根域$("body").append('<iframe src=' + mySrc + ' name="myIframe" id="getData"></frame>');  //向目标网页插入iframevar interval;function start() { $("#getData").attr({"src": mySrc}); interval = setInterval(function() {  window.myIframe.run(getLogitic); //向子域传入回调函数   },10000)}function stop() { clearInterval(interval);}function getLogitic(orderId) { $.ajax({  url: '/query?'+ orderId +'&id=1&valicode=&temp=' + Math.random(),  method: 'GET',  success: function(res) {   console.log(res);    //可以在此再调用子域的方法,向本地文件传输数据  },  error: function(err) {   console.log('err: ', err);  } })}            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表