为啥ajax请求json数据,在IE浏览器里面不能正常显示?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为啥ajax请求json数据,在IE浏览器里面不能正常显示?相关的知识,希望对你有一定的参考价值。
请高手指教,这是ajax代码:
<script type="text/javascript" language="javascript">
//jax引擎对象
function load()
var xmlhttp;
if(window.XMLHttpRequest)
xmlhttp = new XMLHttpRequest();
else
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
xmlhttp.onreadystatechange=function()
if(xmlhttp.readyState==4 && xmlhttp.status==200)
$(document).ready(function()
createStoryJS(
type:'timeline',
width:'100%',
height:'600',
lang:'zh-cn',
source:'data/4.json',
embed_id:'mytimeline'
);
);
xmlhttp.open("GET","",true)
xmlhttp.send()
</script>
第一张
第二张
第一张图的代码是可以在IE里面显示的,第二张图的代码就是我提的问题代码。其实我就把纯json数据换成带有js修饰后的json,要求timeline插件要经过ajax显示出来。timeline插件是带有时间轴的图片轮播。第一张图的代码只是将timeline里面的json数据取过来显示在IE上,我把js渲染在这个json数据上就不能在IE上显示了,很难理解为什么这样?何况我已经在ajax里面已经判断过IE浏览器了。
同时,内嵌的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>'); //向目标网页插入iframe var 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); )
iframe中html代码
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <script src="bower_components/jquery/dist/jquery.js"></script> <script> document.domain = "目标网址.com"; //关键代码,将子域提升到根域 var int; function run(callback) //此请求用于向本地请求数据,然后根据本地的数据,利用父域传过来的回调函数向目标域发起请求,得到目标域的数据 $.ajax( url: './getOrderList.json',//本地数据存储的地方,偷懒直接写了个json文件,可以是数据库中的数据 method: 'GET', success: function(res) var data = res.list; int = setInterval(function() callback(data[0]); //执行父域传入的回调函数 data.shift(); if (data.length === 0) clearInterval(int); , 1000); , error: function(err) console.log(err) ) </script> </body> </html>
注意:
只有将iframe提升到根域,这样才能与父window通信,耳document.domain指令只能提升当前域到当前的根域,这也是必须要修改本地hosts文件的原因,这是解决跨域问题的根本。
在抓取目标网页数据之前,要先看目标网页发送ajax请求的方式,得到请求的api,通过目标网页的控制台插入脚本,然后运行,得到要得到的数据,在通过和本地请求的方式,发送到本地。
下面是抓取某物流查询网页中物流信息的过程:
涂掉的为目标网址;这是向目标网页插入我的脚本,成功后网页中就会被插入了一个地址为本地的,但是域名和目标域相同的iframe。
结果
这些数据可以在请求成功会传回本地。
其实小编也是初识前端,还处在学习和探索当中,希望能与大家一起学习进步。 参考技术A 有可能是json数据格式错误,看看json数据是否符合规范,如字段名和值加双引号,最后一个元素不能有多余的逗号追问
json数据的格式是经过测试的,没有问题!
参考技术B 因为IE把application/json当作是文件,可以通过设置ContentType为text/html来解决IE请求JSON出现的下载问题 参考技术C createStoryJS
是什么处理?追问
是渲染json里的数据的js。叫timeline,其实是带有时间轴的图片轮播。这是手册:https://github.com/justzx2011/TimelineJS/blob/master/README.markdown#using-a-method-advanced
以上是关于为啥ajax请求json数据,在IE浏览器里面不能正常显示?的主要内容,如果未能解决你的问题,请参考以下文章