好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

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

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

熱門標(biāo)簽:超級(jí)大富翁地圖標(biāo)注 機(jī)器人電銷騙局揭秘 硅語電話機(jī)器人公司 越南河內(nèi)地圖標(biāo)注 騰訊地圖標(biāo)注位置能用多久 地圖標(biāo)注項(xiàng)目怎么樣 ai機(jī)器人電銷資源 云呼外撥網(wǎng)絡(luò)電話系統(tǒng) 個(gè)人怎樣在百度地圖標(biāo)注地名

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

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

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

下面就介紹如何解決這個(gè)問題

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

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

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

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

windows下的打開C:\Windows\System32\drivers\etc
這個(gè)文件夾下有一個(gè)hosts文件,如果改過hosts來上谷歌的同學(xué)對(duì)這個(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)的域名之間就不會(huì)存在跨域問題了,這樣就能在本地,通過在目標(biāo)網(wǎng)頁植入iframe標(biāo)簽的方式,向目標(biāo)域發(fā)起跨域請(qǐng)求,取得目標(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=1valicode=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) {
  //此請(qǐng)求用于向本地請(qǐng)求數(shù)據(jù),然后根據(jù)本地的數(shù)據(jù),利用父域傳過來的回調(diào)函數(shù)向目標(biāo)域發(fā)起請(qǐng)求,得到目標(biāo)域的數(shù)據(jù) 
   $.ajax({
    url: './getOrderList.json',//本地?cái)?shù)據(jù)存儲(chǔ)的地方,偷懶直接寫了個(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請(qǐng)求的方式,得到請(qǐng)求的api,通過目標(biāo)網(wǎng)頁的控制臺(tái)插入腳本,然后運(yùn)行,得到要得到的數(shù)據(jù),在通過和本地請(qǐng)求的方式,發(fā)送到本地。
下面是抓取某物流查詢網(wǎng)頁中物流信息的過程:

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


結(jié)果

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

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

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

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

標(biāo)簽:內(nèi)蒙古 洛陽 舟山 海南 遼源 林芝 鄭州 邢臺(tái)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《基于iframe實(shí)現(xiàn)ajax跨域請(qǐng)求 獲取網(wǎng)頁中ajax數(shù)據(jù)》,本文關(guān)鍵詞  基于,iframe,實(shí)現(xiàn),ajax,跨域,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《基于iframe實(shí)現(xiàn)ajax跨域請(qǐng)求 獲取網(wǎng)頁中ajax數(shù)據(jù)》相關(guān)的同類信息!
  • 本頁收集關(guān)于基于iframe實(shí)現(xiàn)ajax跨域請(qǐng)求 獲取網(wǎng)頁中ajax數(shù)據(jù)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 快穿高h肉文| 欧美人禽性动交异族另类| 国产老女人视频| 啊出水了用力潘金莲| 成人免费A片???白浆| x88在线AV| 欧美成人激情视频| 乐安县| 美乳弹出来RION| 中文字幕第30页| 男女后进式猛烈XX00免费漫画| 国产玖玖| 白洁少妇系列H| 日本初裸写真片HD在线DVD| 国产精品啪| 亚洲五月综合缴情综合久久| 国产日韩欧美精品一区二区三区| 精品一区二区三区秋霞视频| 91狠狠色综合久久久夜色撩人| 91福利在线三上悠亚| a级黄色小说| 日本精品毛片无码一区到三区| 男女交性配视频全免费| 精品国产一区二区三区精东影业| 法国黄色片| 欧美国产高潮XXXX1819| 盗摄精品AV一区二区三区| 手机免费看一级片| 鸭王免费观看| 在线成人影视| 免费观看韩国理论片| 性88分钟| xxx护士丝袜激情| 《乳色吐息ova1~2》| 体内?精69XXHD40一50| av电影在线免费看| 91亚洲国产成人久久精品麻豆| 麻豆性视频| 我和60岁老妇乱说伦小说| 一级特级欧美午夜片免费观看| 一级做a爰片久久毛片潮喷动漫 |