欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2016年01月20日 14:17:06   作者:wangcong  
這篇文章主要介紹了基于iframe實(shí)現(xiàn)ajax跨域請求,并獲取網(wǎng)頁中ajax數(shù)據(jù),如何利用網(wǎng)頁ajax請求暴露出來的接口去抓取網(wǎng)頁數(shù)據(jù)?需要的朋友可以參考下

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

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

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

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

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

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

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

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

windows下的打開C:\Windows\System32\drivers\etc
這個(gè)文件夾下有一個(gè)hosts文件,如果改過hosts來上谷歌的同學(xué)對這個(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)的域名之間就不會存在跨域問題了,這樣就能在本地,通過在目標(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ù)存儲的地方,偷懶直接寫了個(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請求的方式,得到請求的api,通過目標(biāo)網(wǎng)頁的控制臺插入腳本,然后運(yùn)行,得到要得到的數(shù)據(jù),在通過和本地請求的方式,發(fā)送到本地。
下面是抓取某物流查詢網(wǎng)頁中物流信息的過程:

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


結(jié)果

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

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

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

相關(guān)文章

  • ajax提交url與ajax提交表單的詳細(xì)比較

    ajax提交url與ajax提交表單的詳細(xì)比較

    本篇文章主要是對ajax提交url與ajax提交表單的區(qū)別進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-02-02
  • Ajax()方法如何與后臺交互

    Ajax()方法如何與后臺交互

    Ajax全稱為“Asynchronous JavaScript and XML”(異步JavaScript和XML),是指一種創(chuàng)建交互式網(wǎng)頁應(yīng)用的網(wǎng)頁開發(fā)技術(shù)。Ajax技術(shù)是目前在瀏覽器中通過JavaScript腳本可以使用的所有技術(shù)的集合
    2016-03-03
  • ajax 調(diào)用后臺方法大家可以討論下

    ajax 調(diào)用后臺方法大家可以討論下

    我曾使用過的三種調(diào)用后臺的代碼,需要的朋友可以參考下,如果發(fā)現(xiàn)更好的可以留言。
    2009-10-10
  • ASP.NET與Ajax的實(shí)現(xiàn)方式小總結(jié)

    ASP.NET與Ajax的實(shí)現(xiàn)方式小總結(jié)

    Ajax 應(yīng)該不是一項(xiàng)技術(shù),是一種思想而已,跟 ASP.NET 以及其它 Web 開發(fā)語言沒有什么太大關(guān)系,這里只是談?wù)?ASP.NET 中目前使用的 Ajax 技術(shù)以及其它一些實(shí)現(xiàn) Ajax 的優(yōu)秀框架。感興趣的朋友跟著小編一起學(xué)習(xí)asp.net與ajax的實(shí)現(xiàn)方式
    2015-09-09
  • 十大最佳Ajax教程收集(圖文)

    十大最佳Ajax教程收集(圖文)

    Ajax通常被認(rèn)為是一門單獨(dú)的語言,實(shí)際上它是很多語言的集合包括DHTML, Javascript, XML 和JSON,全稱為Asynchronous JavaScript and XML(異步JavaScript和XML),是由Jesse James Gaiiett創(chuàng)造的名詞。
    2010-02-02
  • 一個(gè)偽ajax圖片上傳代碼實(shí)現(xiàn)示例

    一個(gè)偽ajax圖片上傳代碼實(shí)現(xiàn)示例

    這篇文章主要介紹了自己寫的一個(gè)偽ajax圖片上傳實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2014-03-03
  • ajax實(shí)現(xiàn)excel報(bào)表導(dǎo)出

    ajax實(shí)現(xiàn)excel報(bào)表導(dǎo)出

    這篇文章主要為大家詳細(xì)介紹了ajax實(shí)現(xiàn)excel報(bào)表導(dǎo)出,解決亂碼問題,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • AJAX 實(shí)時(shí)讀取輸入文本(php)

    AJAX 實(shí)時(shí)讀取輸入文本(php)

    客戶端String.php,服務(wù)器端String_check.php,很簡單的實(shí)現(xiàn)。
    2009-11-11
  • AJAX簡歷系統(tǒng)附j(luò)s文件

    AJAX簡歷系統(tǒng)附j(luò)s文件

    AJAX簡歷系統(tǒng)附j(luò)s文件...
    2007-08-08
  • 如何通過axios發(fā)起Ajax請求(最新推薦)

    如何通過axios發(fā)起Ajax請求(最新推薦)

    Axios是專注于網(wǎng)絡(luò)數(shù)據(jù)請求的庫,相比于原生的XMLHttpRequest對象,axios簡單易用。相比于Jquery,axios更加輕量化,只專注于網(wǎng)絡(luò)數(shù)據(jù)請求,這篇文章主要介紹了如何通過axios發(fā)起Ajax請求,需要的朋友可以參考下
    2022-11-11

最新評論