婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 基于iframe實現ajax跨域請求 獲取網頁中ajax數據

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

熱門標簽:超級大富翁地圖標注 機器人電銷騙局揭秘 硅語電話機器人公司 越南河內地圖標注 騰訊地圖標注位置能用多久 地圖標注項目怎么樣 ai機器人電銷資源 云呼外撥網絡電話系統 個人怎樣在百度地圖標注地名

大家都知道,在不同域的情況下是不能發送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=1valicode=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跨域技術匯總》,進行深入學習和研究。

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

您可能感興趣的文章:
  • jQuery.ajax 跨域請求webapi設置headers的解決方案
  • 使用Nginx 反向代理來避免 ajax 跨域請求的方法
  • Nginx服務器中處理AJAX跨域請求的配置方法講解
  • jQuery使用ajax跨域請求獲取數據
  • AJAX跨域請求之JSONP獲取JSON數據
  • 基于CORS實現WebApi Ajax 跨域請求解決方法

標簽:內蒙古 洛陽 舟山 海南 遼源 林芝 鄭州 邢臺

巨人網絡通訊聲明:本文標題《基于iframe實現ajax跨域請求 獲取網頁中ajax數據》,本文關鍵詞  基于,iframe,實現,ajax,跨域,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《基于iframe實現ajax跨域請求 獲取網頁中ajax數據》相關的同類信息!
  • 本頁收集關于基于iframe實現ajax跨域請求 獲取網頁中ajax數據的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲欧洲av色图| 99精品在线免费| 日韩av网站免费在线| 99在线精品一区二区三区| 久久久久久久久久久电影| 奇米精品一区二区三区四区| 一色屋精品亚洲香蕉网站| 成人av在线播放网址| 亚洲影院久久精品| 中文字幕制服丝袜一区二区三区| 欧美一区二区美女| 91精品欧美久久久久久动漫| 日韩国产欧美在线观看| 精品久久久三级丝袜| 国产精品小仙女| 中文字幕精品三区| 色狠狠一区二区三区香蕉| 亚洲女人的天堂| 在线亚洲高清视频| 日本欧美一区二区| 久久久久久免费| 91猫先生在线| 久久精品国产亚洲a| 国产精品青草久久| 欧美精品久久一区| 国产精品一线二线三线精华| 亚洲女爱视频在线| 亚洲精品一区二区三区99| 99re8在线精品视频免费播放| 亚洲小说欧美激情另类| 欧美mv日韩mv| 色哟哟精品一区| 蜜桃视频在线观看一区| 亚洲欧美日韩系列| 精品日韩一区二区三区免费视频| 成人sese在线| 日韩国产精品久久久久久亚洲| 国产亚洲人成网站| 91精品久久久久久久久99蜜臂| 成人精品免费视频| 美女www一区二区| 一区二区三区中文在线观看| 欧美一区二区日韩| 91在线观看高清| 久久99国产精品免费网站| 国产精品沙发午睡系列990531| 成人免费视频免费观看| 欧美精品粉嫩高潮一区二区| 青娱乐精品视频在线| 国产人久久人人人人爽| 99久久精品国产精品久久| 亚洲成a人v欧美综合天堂| 久久伊99综合婷婷久久伊| 国产激情视频一区二区在线观看| 亚洲免费在线观看视频| 欧美日韩一级二级| 久久综合给合久久狠狠狠97色69| 五月天婷婷综合| 日韩精品亚洲一区二区三区免费| 国产精品影视网| 国产大陆a不卡| 蜜臀精品一区二区三区在线观看 | 91麻豆精品国产综合久久久久久| 久久精品国产第一区二区三区| 欧美日韩一区二区三区四区五区| 亚洲视频在线观看一区| 日韩欧美你懂的| jizzjizzjizz欧美| 国产一区二区在线影院| 午夜精品在线视频一区| 欧美日韩精品福利| 国内外成人在线视频| 亚洲精品日日夜夜| 精品国产污网站| 欧美日韩精品是欧美日韩精品| 国产成人综合自拍| 男男视频亚洲欧美| 亚洲国产成人av网| 最新中文字幕一区二区三区| 久久久精品国产免费观看同学| 欧美日韩国产精品自在自线| 久久99热国产| 亚洲欧美日本韩国| 亚洲美女少妇撒尿| 亚洲人成网站精品片在线观看| 久久伊人蜜桃av一区二区| 欧美丰满美乳xxx高潮www| 国产精品女人毛片| 中文字幕va一区二区三区| 91在线国产观看| 国产精品久久久久一区二区三区| 国产精品久久久久久久浪潮网站 | 国产女人水真多18毛片18精品视频| 欧美综合亚洲图片综合区| 成人一区二区三区视频在线观看| 九九热在线视频观看这里只有精品| 日韩二区三区在线观看| 午夜影院在线观看欧美| 一区二区久久久| 中文字幕一区二区不卡| 亚洲成人综合在线| 偷拍日韩校园综合在线| 自拍偷拍国产精品| 日本电影亚洲天堂一区| 亚洲bdsm女犯bdsm网站| 亚洲bdsm女犯bdsm网站| 国产在线精品一区二区不卡了 | 欧美麻豆精品久久久久久| 国产精品视频看| 美女视频网站久久| 成人黄动漫网站免费app| 精品国产成人系列| 三级影片在线观看欧美日韩一区二区 | 国产欧美精品一区二区色综合朱莉 | 国产精品污污网站在线观看| 久久精品一区四区| 国产精品丝袜黑色高跟| 一区二区三区在线影院| 免费观看在线综合| 丁香激情综合五月| 国产精品第13页| 亚洲mv在线观看| 国产福利91精品| 国产一区二区网址| 五月天激情综合网| 日韩**一区毛片| 成人不卡免费av| 欧美一级日韩免费不卡| 中文字幕一区二区三区在线播放 | 欧美三区在线观看| 日韩欧美中文字幕公布| 欧美国产日本韩| 丝袜诱惑制服诱惑色一区在线观看 | 欧美三级电影在线观看| 久久九九影视网| 日本女人一区二区三区| 在线观看一区二区视频| 久久久久国产精品人| 日韩精品91亚洲二区在线观看| 美女视频一区二区| 国产婷婷一区二区| 中文字幕一区二区三区不卡| 五月天网站亚洲| 在线视频欧美区| 亚洲欧美一区二区久久| 国产69精品久久777的优势| 日韩一区二区三区四区| 亚洲国产裸拍裸体视频在线观看乱了 | 亚洲高清在线视频| 亚洲小少妇裸体bbw| 亚洲自拍欧美精品| 亚洲免费视频成人| 欧美日韩三级一区二区| 美女一区二区三区在线观看| 欧美精品一区二区三区蜜桃| 国产成人在线看| 亚洲小说欧美激情另类| 成人午夜电影久久影院| 亚洲最大成人综合| 欧美在线色视频| 久久国产精品99精品国产| 中文字幕精品三区| 91麻豆精品国产91久久久资源速度| 亚洲成人精品一区二区| 欧美美女黄视频| 成人禁用看黄a在线| 亚洲精品国产视频| 精品久久久久av影院| 在线视频欧美精品| 国产精品一品二品| 欧美日韩一区二区三区免费看 | 国产成人av在线影院| 亚洲精品久久7777| 久久久综合九色合综国产精品| 国产亚洲一区二区三区在线观看| 欧美日本一区二区| 成人精品免费网站| 九色综合狠狠综合久久| 亚洲国产精品久久久久秋霞影院| 久久精品视频一区二区三区| 欧美日韩国产大片| 在线观看视频一区二区| 成人精品一区二区三区中文字幕| 国产精品福利一区二区| 在线成人免费视频| 91片黄在线观看| 美国十次综合导航| 亚洲国产视频网站| 亚洲欧美日韩久久| 中文字幕精品一区二区精品绿巨人 | 国产三级三级三级精品8ⅰ区| 欧美日本精品一区二区三区| 色婷婷av一区二区三区gif| 国产在线视视频有精品| 亚洲第一综合色| 亚洲成va人在线观看| 亚洲一区二区不卡免费| 亚洲免费视频中文字幕| 一区二区三区在线高清| 亚洲国产一二三|