ajax1

作為一個前端工作者娶桦,跨域問題應(yīng)該是很常見的贾节,處理方式有很多,下邊來說一說我用到過的處理方式衷畦。
1.什么是跨域
只要協(xié)議栗涂、域名、端口有任何一個不同祈争,都被當(dāng)做不同的域斤程,js不能在不同的域之間進(jìn)行通信和傳輸數(shù)據(jù)。
2.跨域的情況
(1) 用ajax向不同的域請求數(shù)據(jù)
(2) 通過js獲取頁面中不同域的框架中的數(shù)據(jù)(常見iframe)
瀏覽器都有一個同源策略菩混,其限制之一就是不能通過ajax的方法去請求不同源中的文檔忿墅,限制之二是瀏覽器中不同域的框架之間是不能進(jìn)行js的交互操作的。
3.跨域的方法
(1) jsonp跨域
原理:創(chuàng)建<script>標(biāo)簽沮峡,利用src屬性跨域(src屬性可以跨域)疚脐,同樣<img>也可以處理跨域
舉個栗子:
test.html -----> http://a.hao123.com/test.html
ajaxData -----> http://b.hao123.com/list
test.html訪問ajaxData需要跨域

<script src="http://b.haha.com/list?callback=dosomething"></script>
<script type="text/javascript">
function dosomething(jsondata) {
// 處理獲取的json數(shù)據(jù)
}
</script>

通過一個script標(biāo)簽引入一個js文件,當(dāng)js文件載入成功后會把需要的json數(shù)據(jù)作為參數(shù)傳入U(xiǎn)RL中指定的函數(shù)并執(zhí)行此函數(shù)邢疙,因?yàn)閍jaxData被當(dāng)作一個js文件來引入棍弄,所以其返回的數(shù)據(jù)必須是一個能執(zhí)行的js文件,所以需要服務(wù)端的配合才行疟游。
局限性:<1> 需要服務(wù)端配合做處理
<2> jsonp只支持“get”請求呼畸,不支持“post”請求
(2) document.domain來跨越子域
原理:設(shè)置相同的主域
舉個栗子:
有一個頁面,它的地址是 http://a.hao123.com/test.html 颁虐, 在這個頁面里面有一個iframe蛮原,它的src是 http://b.hao123.com/test.html , 很顯然,這個頁面與它里面的iframe框架是不同域的另绩,所以我們是無法通過在頁面中書寫js代碼來獲取iframe中的東西的

<iframe src="http://b.hao123.com/test.html" onload="test()" id="iframe"></iframe>
<script type="text/javascript">
document.domain = "haha.com";
function test() {
// 獲取iframe中的數(shù)據(jù)
var cont = document.getElementById('iframe').contentWindow;
}
</script>

注意: <1> document.domain的設(shè)置是有限制的儒陨,我們只能把document.domain設(shè)置成自身或更高一級的父域送漠,且主域必須相同贞让。
<2> 修改document.domain的方法只適用于不同子域的框架間的交互,對ajax訪問的不適用汁针。
(3) 隱藏iframe做代理跨域
如果你想通過ajax的方法去與不同子域的頁面交互干签,除了使用jsonp的方法外津辩,還可以用一個隱藏的iframe來做一個代理。
原理:讓這個隱藏的iframe載入一個與你想要通過ajax獲取數(shù)據(jù)的目標(biāo)頁面處在相同的域的頁面,所以這個iframe中的頁面是可以正常使用ajax去獲取你要的數(shù)據(jù)的喘沿,然后就是通過修改document.domain的方法闸度,讓我們能通過js完全控制這個iframe,這樣我們就可以讓iframe去發(fā)送ajax請求蚜印,然后收到的數(shù)據(jù)我們也可以獲得了莺禁。
還是方法1中的例子,在test.html中訪問ajaxData

<iframe src="http://b.hao123.com/ajaxProxy.html" onload="test()" id="iframe" style="display:none"></iframe>
<script type="text/javascript>
// 設(shè)置相同的主域
document.domain = 'hao123.com';
iframe = document.getElementById('iframe');
iframe.addEventListener('load',function(e) {
// 1.發(fā)送ajax請求數(shù)據(jù)

    // 2.獲取iframe中的數(shù)據(jù)
    var cont = iframe.contentWindow;
    
    // 3.數(shù)據(jù)的處理
    
})

</script>
在梳理一下第3種
<1> test.html中設(shè)置一個隱藏的iframe窄赋,其src為http://b.hao123.com/ajaxProxy.html,與ajaxData處于相同域哟冬,在iframe中訪問ajaxData獲取返回的數(shù)據(jù)
<2> 再利用第二種方法去獲取iframe中的數(shù)據(jù)進(jìn)行處理

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市忆绰,隨后出現(xiàn)的幾起案子浩峡,更是在濱河造成了極大的恐慌,老刑警劉巖错敢,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件翰灾,死亡現(xiàn)場離奇詭異,居然都是意外死亡稚茅,警方通過查閱死者的電腦和手機(jī)纸淮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來亚享,“玉大人咽块,你說我怎么就攤上這事『缃” “怎么了糜芳?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵飒货,是天一觀的道長魄衅。 經(jīng)常有香客問我,道長塘辅,這世上最難降的妖魔是什么晃虫? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮扣墩,結(jié)果婚禮上哲银,老公的妹妹穿的比我還像新娘。我一直安慰自己呻惕,他們只是感情好荆责,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著亚脆,像睡著了一般做院。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天键耕,我揣著相機(jī)與錄音寺滚,去河邊找鬼。 笑死屈雄,一個胖子當(dāng)著我的面吹牛村视,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播酒奶,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蚁孔,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了惋嚎?” 一聲冷哼從身側(cè)響起勒虾,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎瘸彤,沒想到半個月后修然,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡质况,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年愕宋,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片结榄。...
    茶點(diǎn)故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡中贝,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出臼朗,到底是詐尸還是另有隱情邻寿,我是刑警寧澤,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布视哑,位于F島的核電站绣否,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏挡毅。R本人自食惡果不足惜蒜撮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望跪呈。 院中可真熱鬧段磨,春花似錦、人聲如沸耗绿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽误阻。三九已至债蜜,卻和暖如春琉用,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背策幼。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工邑时, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人特姐。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓晶丘,卻偏偏與公主長得像,于是被迫代替她去往敵國和親唐含。 傳聞我的和親對象是個殘疾皇子浅浮,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內(nèi)容

  • 1. 什么是跨域? 跨域一詞從字面意思看捷枯,就是跨域名嘛滚秩,但實(shí)際上跨域的范圍絕對不止那么狹隘。具體概念如下:只要協(xié)議...
    他在發(fā)呆閱讀 822評論 0 0
  • 1. 什么是跨域淮捆? 跨域一詞從字面意思看郁油,就是跨域名嘛,但實(shí)際上跨域的范圍絕對不止那么狹隘攀痊。具體概念如下:只要協(xié)議...
    w_zhuan閱讀 515評論 0 0
  • 什么是跨域桐腌? 2.) 資源嵌入:、苟径、案站、等dom標(biāo)簽,還有樣式中background:url()棘街、@font-fac...
    電影里的夢i閱讀 2,372評論 0 5
  • 五十三:請解釋 JavaScript 中 this 是如何工作的蟆盐。1.方法調(diào)用模式當(dāng)一個函數(shù)被保存為一個對象的屬性...
    Arno_z閱讀 577評論 0 2
  • 大概從兩年前開始吧石挂,健身熱潮忽然席卷朋友圈:有每天都在你追我趕比拼步數(shù)的微信運(yùn)動;有未完成目標(biāo)步數(shù)就必須發(fā)紅包的微...
    嘉陵江上柳葉刀閱讀 436評論 0 0