<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

        基于iframe實(shí)現(xiàn)ajax跨域請求 獲取網(wǎng)頁中ajax數(shù)據(jù)

        來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 22:52:01
        文檔

        基于iframe實(shí)現(xiàn)ajax跨域請求 獲取網(wǎng)頁中ajax數(shù)據(jù)

        基于iframe實(shí)現(xiàn)ajax跨域請求 獲取網(wǎng)頁中ajax數(shù)據(jù):大家都知道,在不同域的情況下是不能發(fā)送ajax請求的,瀏覽器會報(bào)如下錯誤: 同時,內(nèi)嵌的iframe中無法進(jìn)行跨域通信的,也就是說不同域的iframe是無法互相讀取數(shù)據(jù)的(當(dāng)然利用hash變化可以從父window傳入數(shù)據(jù)到子iframe,不過并沒有什么意義)。iframe
        推薦度:
        導(dǎo)讀基于iframe實(shí)現(xiàn)ajax跨域請求 獲取網(wǎng)頁中ajax數(shù)據(jù):大家都知道,在不同域的情況下是不能發(fā)送ajax請求的,瀏覽器會報(bào)如下錯誤: 同時,內(nèi)嵌的iframe中無法進(jìn)行跨域通信的,也就是說不同域的iframe是無法互相讀取數(shù)據(jù)的(當(dāng)然利用hash變化可以從父window傳入數(shù)據(jù)到子iframe,不過并沒有什么意義)。iframe

        大家都知道,在不同域的情況下是不能發(fā)送ajax請求的,瀏覽器會報(bào)如下錯誤:

        同時,內(nèi)嵌的iframe中無法進(jìn)行跨域通信的,也就是說不同域的iframe是無法互相讀取數(shù)據(jù)的(當(dāng)然利用hash變化可以從父window傳入數(shù)據(jù)到子iframe,不過并沒有什么意義)。iframe跨域通信時,瀏覽器會報(bào)如下錯誤:

        其實(shí)這兩個問題都是由于跨域造成的。

        下面就介紹如何解決這個問題。

        其實(shí)問題的關(guān)鍵就在于,瀏覽器在解析ajax請求地址時會和當(dāng)前網(wǎng)頁的地址進(jìn)行比較,如果是跨域的,那就禁止掉并且報(bào)錯。那么我們?nèi)绻尀g覽器解析出的ajax地址和當(dāng)前網(wǎng)頁的解析地址一樣,瀏覽器不就不會禁止我們的請求了么。

        那么瀏覽器是如何解析url的呢?

        首先當(dāng)瀏覽器訪問一個域名時,會查詢本地的DNS緩存中是否有關(guān)于這個網(wǎng)址對應(yīng)ip地址,如果有的話,直接從本地取得ip地址然后訪問,如果沒有,瀏覽器就會向DNS服務(wù)器發(fā)出DNS請求獲得該域名對應(yīng)的ip地址然后存入本地緩存然后訪問。

        那么介于以上問題,我們只要在本地偽造一條域名的解析方式,然后再通過偽造的域和目標(biāo)域進(jìn)行跨域請求不就可以了么。

        windows下的打開C:\Windows\System32\drivers\etc
        這個文件夾下有一個hosts文件,如果改過hosts來上谷歌的同學(xué)對這個應(yīng)該很熟悉,在hosts文件里加上這樣一段代碼:

        127.0.0.1         a.目標(biāo)網(wǎng)址.com

        這樣你的訪問a.目標(biāo)網(wǎng)址.com就和訪問localhost一樣了,這樣做的目的是方便搭起本地的服務(wù)時,本地的服務(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ù)存儲的地方,偷懶直接寫了個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)頁中物流信息的過程:

      1. 涂掉的為目標(biāo)網(wǎng)址;這是向目標(biāo)網(wǎng)頁插入我的腳本,成功后網(wǎng)頁中就會被插入了一個地址為本地的,但是域名和目標(biāo)域相同的iframe。

      2. 結(jié)果

        這些數(shù)據(jù)可以在請求成功會傳回本地。

        更多精彩內(nèi)容,請點(diǎn)擊《ajax跨域技術(shù)匯總》,進(jìn)行深入學(xué)習(xí)和研究。

        其實(shí)小編也是初識前端,還處在學(xué)習(xí)和探索當(dāng)中,希望能與大家一起學(xué)習(xí)進(jìn)步。

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        基于iframe實(shí)現(xiàn)ajax跨域請求 獲取網(wǎng)頁中ajax數(shù)據(jù)

        基于iframe實(shí)現(xiàn)ajax跨域請求 獲取網(wǎng)頁中ajax數(shù)據(jù):大家都知道,在不同域的情況下是不能發(fā)送ajax請求的,瀏覽器會報(bào)如下錯誤: 同時,內(nèi)嵌的iframe中無法進(jìn)行跨域通信的,也就是說不同域的iframe是無法互相讀取數(shù)據(jù)的(當(dāng)然利用hash變化可以從父window傳入數(shù)據(jù)到子iframe,不過并沒有什么意義)。iframe
        推薦度:
        • 熱門焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: **俄罗斯毛片免费| 亚洲?V无码乱码国产精品 | 亚洲日韩中文字幕| 国外成人免费高清激情视频| 一区二区三区视频免费观看| 亚洲综合日韩中文字幕v在线| 免费高清在线影片一区| 免费人成黄页在线观看日本| 亚洲综合小说另类图片动图| 亚洲线精品一区二区三区影音先锋| 成年人网站免费视频| 国产精品免费看久久久香蕉| 国产亚洲中文日本不卡二区| 亚洲精品国产字幕久久不卡| 四虎免费大片aⅴ入口| 亚洲一区免费观看| 国内成人精品亚洲日本语音 | 视频一区二区三区免费观看| 久久久久久久亚洲Av无码| 午夜亚洲av永久无码精品| 最近中文字幕免费mv在线视频| 美女黄网站人色视频免费| 亚洲六月丁香六月婷婷色伊人| 在线亚洲人成电影网站色www| 成年男女免费视频网站| 精品一区二区三区无码免费视频| 免费一级毛片在线播放视频免费观看永久| 久久青青草原亚洲av无码app | 在线观看免费播放av片| 亚洲av综合日韩| ww亚洲ww在线观看国产| 久久青青草原亚洲AV无码麻豆 | 在线观看亚洲精品国产| 免费黄色毛片视频| 免费H网站在线观看的| 久久精品私人影院免费看| 国产VA免费精品高清在线| 风间由美在线亚洲一区| 亚洲久悠悠色悠在线播放| 亚洲美女视频免费| 亚洲日韩图片专区第1页|