国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > AJAX > 正文

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

2024-09-01 08:28:09
字體:
來源:轉載
供稿:網友

大家都知道,在不同域的情況下是不能發送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>');  //向目標網頁插入iframevar 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);  } })}            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 富川| 安陆市| 涿州市| 宁安市| 永和县| 望江县| 石棉县| 图木舒克市| 舒兰市| 广灵县| 台南市| 确山县| 慈利县| 左权县| 平原县| 盈江县| 阿坝县| 晋宁县| 宜兰市| 富源县| 郓城县| 确山县| 河曲县| 盐源县| 屏山县| 宾阳县| 连平县| 五大连池市| 门头沟区| 布尔津县| 拉萨市| 东乌珠穆沁旗| 定日县| 友谊县| 石嘴山市| 炎陵县| 泾源县| 永宁县| 芦山县| 铜山县| 丹巴县|