JS之同源策略和跨域

同源策略(Same Origin Policy)

瀏覽器處于安全方面的考慮海雪,只允許與本域下的接口交互笆豁。不同源的客戶端腳本在沒有明確授權(quán)的情況下,不能讀寫對方的資源。

本域指的是:

  • 同協(xié)議:都是http或https
  • 同域名:如http://a.com/jshttp://a.com/css(域名必須完全相同)
  • 同端口:如都是80端口或8080端口

不同源的例子:

需要注意:對于當前頁面來說頁面存放的js文件的域不重要扔仓,重要的是加載該JS頁面所在什么域

跨域

JSONP

HTML中script標簽可以加載其他域下的js,比如我們經(jīng)常引入一個其他域下的線上CDN的Jquery∨昼停可以利用這個特性實現(xiàn)從其他域獲取數(shù)據(jù)。

<script src="http://api.jirengu.com/weather.php"></script>

這時候會向天氣接口發(fā)送請求獲取數(shù)據(jù)阀圾,獲取數(shù)據(jù)后作為js來執(zhí)行哪廓。但是有個問題,數(shù)據(jù)是JSON格式的數(shù)據(jù)初烘,直接作為JS運行的話若何得到數(shù)據(jù)來操作呢涡真?

<script src="http://api.jirengu.com/weather.php?callback=showData"></script>

這個請求到達后端后,后端回去解析callback這個參數(shù)獲取到字符串showData肾筐,在發(fā)送數(shù)據(jù)做如下處理:

之前返回數(shù)據(jù)是個對象哆料,如:{"city": "hangzhou", "weather": "晴天"},現(xiàn)在返回數(shù)據(jù):showData({"city": "hangzhou", "weather": "晴天"})

script標簽在加載數(shù)據(jù)后會把showData({"city": "hangzhou", "weather": "晴天"})作為js來執(zhí)行吗铐,實際上就是調(diào)用showData函數(shù)东亦,同時參數(shù)是{"city": "hangzhou", "weather": "晴天"}

用戶只需要提前在頁面定義好showData這個全局函數(shù),在函數(shù)內(nèi)部處理參數(shù)即可唬渗。

<script>
function showData(ret){
console.log(ret);
}
</script>
<script src="http://api.jirengu.com/weather.php?callback=showData"></script>

這就是JSONP(JSON with padding)

JSONP是通過script標簽加載數(shù)據(jù)的方式去獲取數(shù)據(jù)當做JS代碼來執(zhí)行典阵,提前在頁面上聲明一個函數(shù),函數(shù)名通過接口傳參的方式傳給后臺镊逝,后臺解析到函數(shù)名后在原始數(shù)據(jù)上包裹這個函數(shù)名壮啊,發(fā)給前端。

JSONP需要對應(yīng)接口的后端配合才能實現(xiàn)撑蒜。

CORS

CORS全稱是跨域資源共享(Cross-Origin Resource Sharing)歹啼,是一種Ajax跨域請求資源的方式,支持現(xiàn)代瀏覽器座菠,IE支持10以上狸眼。

當使用XMLHTTPRequest發(fā)送請求時:

  1. 瀏覽器發(fā)現(xiàn)該請求不符合同源策略,會被該請求加一個請求頭:Origin
  2. 后臺進行一些列處理浴滴,如果確定接收請求則在返回結(jié)果中加入一個響應(yīng)頭:Access-Control-Allow-Origin
  3. 瀏覽器判斷該響應(yīng)頭時候包含Origin的值拓萌,如果有,瀏覽器會處理響應(yīng)巡莹,我們就可以拿到響應(yīng)數(shù)據(jù)司志,如果沒有甜紫,瀏覽器直接駁回降宅,我們無法拿到響應(yīng)數(shù)據(jù)

CROS的表象會讓人覺得它與同源的Ajax請求沒有區(qū)別,代碼完全一樣囚霸。

降域

iframe的降域通信

只有主域名相同才能降域通信腰根,如a.baidu.com 和 b.baidu.com

在兩個頁面中加入:

document.domain = 'baidu.com';

postMessage

postMessage是HTML5新增的一個解決跨域的一個方法,萬惡的ie6,7不支持

postMessage()方法允許來自不同源的腳本采用異步方式進行有限的通信拓型,可以實現(xiàn)跨文本檔额嘿、多窗口瘸恼、跨域消息傳遞。

a.html

<script type="text/javascript">
    window.addEventListener('message',function(e){
        console.log(e.data);        //hello world
        console.log(e.origin);      //http://127.0.0.1:8020 所傳來數(shù)據(jù)的域

    })
</script>

b.html

<script type="text/javascript">
    window.parent.postMessage('hello world','*');    //在被嵌套的iframe的頁面中寫入這樣一段代碼
</script>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末册养,一起剝皮案震驚了整個濱河市东帅,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌球拦,老刑警劉巖靠闭,帶你破解...
    沈念sama閱讀 216,997評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異坎炼,居然都是意外死亡愧膀,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評論 3 392
  • 文/潘曉璐 我一進店門谣光,熙熙樓的掌柜王于貴愁眉苦臉地迎上來檩淋,“玉大人,你說我怎么就攤上這事萄金◇霸茫” “怎么了?”我有些...
    開封第一講書人閱讀 163,359評論 0 353
  • 文/不壞的土叔 我叫張陵捡絮,是天一觀的道長熬芜。 經(jīng)常有香客問我,道長福稳,這世上最難降的妖魔是什么涎拉? 我笑而不...
    開封第一講書人閱讀 58,309評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮的圆,結(jié)果婚禮上鼓拧,老公的妹妹穿的比我還像新娘。我一直安慰自己越妈,他們只是感情好季俩,可當我...
    茶點故事閱讀 67,346評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著梅掠,像睡著了一般酌住。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上阎抒,一...
    開封第一講書人閱讀 51,258評論 1 300
  • 那天酪我,我揣著相機與錄音,去河邊找鬼且叁。 笑死都哭,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播欺矫,決...
    沈念sama閱讀 40,122評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼纱新,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了穆趴?” 一聲冷哼從身側(cè)響起脸爱,我...
    開封第一講書人閱讀 38,970評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎未妹,沒想到半個月后阅羹,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,403評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡教寂,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,596評論 3 334
  • 正文 我和宋清朗相戀三年捏鱼,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片酪耕。...
    茶點故事閱讀 39,769評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡导梆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出迂烁,到底是詐尸還是另有隱情看尼,我是刑警寧澤,帶...
    沈念sama閱讀 35,464評論 5 344
  • 正文 年R本政府宣布盟步,位于F島的核電站藏斩,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏却盘。R本人自食惡果不足惜狰域,卻給世界環(huán)境...
    茶點故事閱讀 41,075評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望黄橘。 院中可真熱鬧兆览,春花似錦、人聲如沸塞关。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽帆赢。三九已至小压,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間椰于,已是汗流浹背怠益。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留廉羔,地道東北人溉痢。 一個月前我還...
    沈念sama閱讀 47,831評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像憋他,于是被迫代替她去往敵國和親孩饼。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,678評論 2 354

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

  • Section1竹挡、為什么要跨域镀娶? 自古以來(1995年起),為了用戶的信息安全揪罕,瀏覽器就引入了同源策略梯码。那么同源策...
    qhaobaba閱讀 382評論 0 0
  • 1:什么是同源策略 瀏覽器出于安全及用戶隱私方面的考慮,只允許腳本與本域下的接口交互好啰。不同源的客戶端腳本在沒有明確...
    饑人谷_bigJiao閱讀 251評論 0 1
  • 參考:瀏覽器的同源策略瀏覽器同源政策及其規(guī)避方法同源政策 什么是同源策略轩娶? 同源策略限制了從同一個源加載的文檔或腳...
    DHFE閱讀 539評論 0 0
  • 1.同源策略(Same origin Policy) 瀏覽器出于安全方面的考慮,只允許與本域下的接口交互框往。不同源的...
    好奇男孩閱讀 332評論 0 2
  • 題目1: 什么是同源策略 同源策略(Same origin Policy)瀏覽器出于安全方面的考慮鳄抒,只允許與本域下...
    饑人谷_Jack閱讀 304評論 0 0