這篇文章給大家分享的是有關(guān)基于iframe如何實(shí)現(xiàn)ajax跨域請求以及獲取網(wǎng)頁中ajax數(shù)據(jù)的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。
成都創(chuàng)新互聯(lián)公司是工信部頒發(fā)資質(zhì)IDC服務(wù)器商,為用戶提供優(yōu)質(zhì)的資陽托管服務(wù)器服務(wù)
大家都知道,在不同域的情況下是不能發(fā)送ajax請求的,瀏覽器會報(bào)如下錯(cuò)誤:
同時(shí),內(nèi)嵌的iframe中無法進(jìn)行跨域通信的,也就是說不同域的iframe是無法互相讀取數(shù)據(jù)的(當(dāng)然利用hash變化可以從父window傳入數(shù)據(jù)到子iframe,不過并沒有什么意義)。iframe跨域通信時(shí),瀏覽器會報(bào)如下錯(cuò)誤:
其實(shí)這兩個(gè)問題都是由于跨域造成的。
下面就介紹如何解決這個(gè)問題。
其實(shí)問題的關(guān)鍵就在于,瀏覽器在解析ajax請求地址時(shí)會和當(dāng)前網(wǎng)頁的地址進(jìn)行比較,如果是跨域的,那就禁止掉并且報(bào)錯(cuò)。那么我們?nèi)绻尀g覽器解析出的ajax地址和當(dāng)前網(wǎng)頁的解析地址一樣,瀏覽器不就不會禁止我們的請求了么。
那么瀏覽器是如何解析url的呢?
首先當(dāng)瀏覽器訪問一個(gè)域名時(shí),會查詢本地的DNS緩存中是否有關(guān)于這個(gè)網(wǎng)址對應(yīng)ip地址,如果有的話,直接從本地取得ip地址然后訪問,如果沒有,瀏覽器就會向DNS服務(wù)器發(fā)出DNS請求獲得該域名對應(yīng)的ip地址然后存入本地緩存然后訪問。
那么介于以上問題,我們只要在本地偽造一條域名的解析方式,然后再通過偽造的域和目標(biāo)域進(jìn)行跨域請求不就可以了么。
windows下的打開C:\Windows\System32\drivers\etc
這個(gè)文件夾下有一個(gè)hosts文件,如果改過hosts來上谷歌的同學(xué)對這個(gè)應(yīng)該很熟悉,在hosts文件里加上這樣一段代碼:
127.0.0.1 a.目標(biāo)網(wǎng)址.com
這樣你的訪問a.目標(biāo)網(wǎng)址.com就和訪問localhost一樣了,這樣做的目的是方便搭起本地的服務(wù)時(shí),本地的服務(wù)和目標(biāo)的域名之間就不會存在跨域問題了,這樣就能在本地,通過在目標(biāo)網(wǎng)頁植入iframe標(biāo)簽的方式,向目標(biāo)域發(fā)起跨域請求,取得目標(biāo)域的數(shù)據(jù)。
直接上代碼(用了jQuery)
腳本代碼,直接插在父域
var mySrc = "http://a.目標(biāo)網(wǎng)址.com:9000/myIframe.html"; document.domain = "目標(biāo)網(wǎng)址.com"; //關(guān)鍵代碼,將域提升到根域 $("body").append('<iframe src=' + mySrc + ' name="myIframe" id="getData"></frame>'); //向目標(biāo)網(wǎng)頁插入iframe var interval; function start() { $("#getData").attr({"src": mySrc}); interval = setInterval(function() { window.myIframe.run(getLogitic); //向子域傳入回調(diào)函數(shù) },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); //可以在此再調(diào)用子域的方法,向本地文件傳輸數(shù)據(jù) }, 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 = "目標(biāo)網(wǎng)址.com"; //關(guān)鍵代碼,將子域提升到根域 var int; function run(callback) { //此請求用于向本地請求數(shù)據(jù),然后根據(jù)本地的數(shù)據(jù),利用父域傳過來的回調(diào)函數(shù)向目標(biāo)域發(fā)起請求,得到目標(biāo)域的數(shù)據(jù) $.ajax({ url: './getOrderList.json',//本地?cái)?shù)據(jù)存儲的地方,偷懶直接寫了個(gè)json文件,可以是數(shù)據(jù)庫中的數(shù)據(jù) method: 'GET', success: function(res) { var data = res.list; int = setInterval(function(){ callback(data[0]); //執(zhí)行父域傳入的回調(diào)函數(shù) data.shift(); if (data.length === 0) clearInterval(int); }, 1000); }, error: function(err) { console.log(err) } }) } </script> </body> </html>
注意:
只有將iframe提升到根域,這樣才能與父window通信,耳document.domain指令只能提升當(dāng)前域到當(dāng)前的根域,這也是必須要修改本地hosts文件的原因,這是解決跨域問題的根本。
在抓取目標(biāo)網(wǎng)頁數(shù)據(jù)之前,要先看目標(biāo)網(wǎng)頁發(fā)送ajax請求的方式,得到請求的api,通過目標(biāo)網(wǎng)頁的控制臺插入腳本,然后運(yùn)行,得到要得到的數(shù)據(jù),在通過和本地請求的方式,發(fā)送到本地。
下面是抓取某物流查詢網(wǎng)頁中物流信息的過程:
涂掉的為目標(biāo)網(wǎng)址;這是向目標(biāo)網(wǎng)頁插入我的腳本,成功后網(wǎng)頁中就會被插入了一個(gè)地址為本地的,但是域名和目標(biāo)域相同的iframe。
結(jié)果
這些數(shù)據(jù)可以在請求成功會傳回本地。
感謝各位的閱讀!關(guān)于“基于iframe如何實(shí)現(xiàn)ajax跨域請求以及獲取網(wǎng)頁中ajax數(shù)據(jù)”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
網(wǎng)站名稱:基于iframe如何實(shí)現(xiàn)ajax跨域請求以及獲取網(wǎng)頁中ajax數(shù)據(jù)
鏈接地址:http://chinadenli.net/article42/pgosec.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航、標(biāo)簽優(yōu)化、解決方案、搜索引擎優(yōu)化、網(wǎng)站改版、定制網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)