• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題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
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    基于iframe實現ajax跨域請求 獲取網頁中ajax數據

    來源:懂視網 責編:小采 時間:2020-11-27 22:52:01
    文檔

    基于iframe實現ajax跨域請求 獲取網頁中ajax數據

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

    大家都知道,在不同域的情況下是不能發送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>'); //向目標網頁插入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。

  • 結果

    這些數據可以在請求成功會傳回本地。

    更多精彩內容,請點擊《ajax跨域技術匯總》,進行深入學習和研究。

    其實小編也是初識前端,還處在學習和探索當中,希望能與大家一起學習進步。

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

    文檔

    基于iframe實現ajax跨域請求 獲取網頁中ajax數據

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

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 精品人人妻人人澡人人爽人人| 久久精品成人免费网站| 国产亚洲精品xxx| 国产精品视频久久| 青青热久久国产久精品 | 中文字幕在线精品视频入口一区| 免费精品国产自产拍在线观看| 人人妻人人澡人人爽人人精品| 精品人妻大屁股白浆无码| 国产午夜精品理论片久久| 欧美精品整片300页| 精品福利一区二区三| 亚洲AV永久青草无码精品| 91久久精品91久久性色| 93精91精品国产综合久久香蕉| 国产乱人伦偷精品视频| jiucao在线观看精品| 人妻少妇偷人精品无码| 无码日韩精品一区二区人妻| 精品国精品国产自在久国产应用| 亚洲国产成人a精品不卡在线| 精品亚洲A∨无码一区二区三区| 国产精品久久久久久搜索| 亚洲精品国产成人片| 99re8这里有精品热视频免费| 无码乱码观看精品久久| 国产原创精品 正在播放| 亚洲精品国产美女久久久| 欧美精品福利在线视频| 精品无码久久久久久久动漫| 久久精品毛片免费观看| 真实国产乱子伦精品一区二区三区| 精品国产第1页| 91精品欧美综合在线观看| 精品无码一区在线观看| 亚洲精品乱码久久久久久久久久久久 | 欧美精品国产一区二区三区| 久久激情亚洲精品无码?V| 久久97久久97精品免视看| 精品久久久久久国产免费了| 国产精品男男视频一区二区三区|