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

這篇文章給大家分享的是有關基于iframe如何實現ajax跨域請求以及獲取網頁中ajax數據的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

成都創新互聯公司是工信部頒發資質IDC服務器商,為用戶提供優質的資陽托管服務器服務

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

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

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

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

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

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

其實問題的關鍵就在于,瀏覽器在解析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。

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

結果

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

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

感謝各位的閱讀!關于“基于iframe如何實現ajax跨域請求以及獲取網頁中ajax數據”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

網站名稱:基于iframe如何實現ajax跨域請求以及獲取網頁中ajax數據
鏈接地址:http://m.kartarina.com/article42/pgosec.html

成都網站建設公司_創新互聯,為您提供網站導航、標簽優化、解決方案搜索引擎優化、網站改版、定制網站

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

1成都定制網站建設
主站蜘蛛池模板: 日韩亚洲AV无码一区二区不卡| a级毛片无码免费真人| 亚洲成A人片在线观看无码3D| 人妻少妇精品无码专区动漫| 亚洲午夜无码AV毛片久久| 免费无码av片在线观看| 久久久久精品国产亚洲AV无码| 国产精品午夜无码AV天美传媒| 亚洲国产精品无码久久SM | 69成人免费视频无码专区| 亚洲人成无码久久电影网站| 中文字幕人成无码人妻| 国产V片在线播放免费无码| 亚洲中文无码av永久| 惠民福利中文字幕人妻无码乱精品| 亚洲AV综合色区无码一区| 日韩精品无码免费视频| 无码AV大香线蕉| 无码福利一区二区三区| 国产成人AV片无码免费| 亚洲v国产v天堂a无码久久| 精品久久久久久无码中文字幕一区| 午夜无码伦费影视在线观看| 最新无码A∨在线观看| 无码专区HEYZO色欲AV| 亚洲av中文无码乱人伦在线观看 | 久久久精品无码专区不卡| 一本无码人妻在中文字幕免费 | 67194成l人在线观看线路无码| 日韩精品无码视频一区二区蜜桃| 精品久久久无码中文字幕边打电话| 91精品久久久久久无码| 亚洲AV无码专区国产乱码电影| 中文字幕av无码专区第一页| 日韩精品无码免费专区午夜不卡 | 精品无码一区二区三区电影| 久久老子午夜精品无码| 人妻丰满熟妇AV无码区乱| 久久精品无码精品免费专区| 亚洲AV成人噜噜无码网站| 亚洲爆乳大丰满无码专区|