script的crossorigin屬性

通過script標(biāo)簽加載跨域資源是一種常用的跨域請求解決方式笆环。那在HTML5中新增的crossorigin屬性攒至,有什么作用呢?難道以前不用 crossorigin 屬性的時(shí)候躁劣,會(huì)出什么問題嗎?到底可能會(huì)出什么問題呢库菲?

當(dāng)引入跨域的腳本時(shí)账忘,如果這個(gè)腳本有錯(cuò)誤,因?yàn)闉g覽器的限制(根本原因是協(xié)議的規(guī)定)熙宇,是拿不到錯(cuò)誤信息的鳖擒。當(dāng)本地嘗試使用 window.onerror 去記錄腳本的錯(cuò)誤時(shí),跨域腳本的錯(cuò)誤只會(huì)返回 Script error烫止。

image

而 HTML5 新的規(guī)定蒋荚,是可以允許本地獲取到跨域腳本的錯(cuò)誤信息的,但有兩個(gè)條件:

  1. 跨域腳本的服務(wù)器必須通過 Access-Control-Allow-Origin 頭信息允許當(dāng)前域名可以獲取錯(cuò)誤信息
  2. 網(wǎng)頁里的 script 標(biāo)簽也必須指明 src 屬性指定的地址是支持跨域的地址馆蠕,也就是 crossorigin 屬性期升。

有了這兩個(gè)條件,就可以獲取跨域腳本的錯(cuò)誤信息:

image

但事情還是不夠明朗互躬,看起來跨域腳本報(bào)個(gè)錯(cuò)也沒什么啊播赁,為什么瀏覽器(準(zhǔn)確說是 HTTP 協(xié)議)這么軸,非要規(guī)定默認(rèn)情況頁面是不能獲取跨域腳本錯(cuò)誤信息的呢吼渡?

這其實(shí)跟網(wǎng)絡(luò)安全有關(guān)容为,不妨舉一個(gè)例子來說明。
我們先假設(shè)瀏覽器默認(rèn)可以將跨域腳本的錯(cuò)誤信息返回寺酪。
這個(gè)時(shí)候我在我的博客里寫下如下代碼:

<script src="http://某個(gè)銀行/會(huì)員信息網(wǎng)址">
<script src="http://某個(gè)銀行2/會(huì)員信息網(wǎng)址">
...

注意 src 里面提到地址坎背,都是 HTML 頁面的地址,當(dāng)成 JS 來執(zhí)行寄雀,肯定是會(huì)報(bào)錯(cuò)的得滤。
因?yàn)槲覀兗僭O(shè)瀏覽器能報(bào)具體錯(cuò)誤,這個(gè)錯(cuò)誤可能是類似于:

“請登錄” is undefined.
“您好” is undefined.
我們通過報(bào)錯(cuò)信息的不一致咙俩,可能可以推斷出當(dāng)前訪問我博客的會(huì)員在某某銀行是否有賬號耿戚。雖然不是什么大問題,但隱私的確是泄漏了阿趁,如果我是攻擊者我可能會(huì)通過判斷會(huì)員在某家銀行是否有賬號膜蛔,『精準(zhǔn)』推送相關(guān)的釣魚網(wǎng)站給他。

說清楚了來龍去脈脖阵,我們就可以更好的判斷皂股,我們是否真的需要給 script 標(biāo)簽加上 crossorigin 屬性了。另外除了 script命黔,所有能引入跨域資源的標(biāo)簽包括 link 和 img 之類呜呐,都有一樣的屬性,但他們的跨域?qū)傩詢H跟 canvas 有關(guān)就斤。關(guān)于 <img> / <link> 的 crossorigin 屬性解釋,見此篇文章蘑辑。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末洋机,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子洋魂,更是在濱河造成了極大的恐慌绷旗,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件副砍,死亡現(xiàn)場離奇詭異衔肢,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)豁翎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進(jìn)店門角骤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人心剥,你說我怎么就攤上這事邦尊。” “怎么了刘陶?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵胳赌,是天一觀的道長。 經(jīng)常有香客問我匙隔,道長疑苫,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任纷责,我火速辦了婚禮捍掺,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘再膳。我一直安慰自己挺勿,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布喂柒。 她就那樣靜靜地躺著不瓶,像睡著了一般。 火紅的嫁衣襯著肌膚如雪灾杰。 梳的紋絲不亂的頭發(fā)上蚊丐,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天,我揣著相機(jī)與錄音艳吠,去河邊找鬼麦备。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的凛篙。 我是一名探鬼主播黍匾,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼呛梆!你這毒婦竟也來了锐涯?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤削彬,失蹤者是張志新(化名)和其女友劉穎全庸,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體融痛,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年神僵,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了雁刷。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,064評論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡保礼,死狀恐怖沛励,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情炮障,我是刑警寧澤目派,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站胁赢,受9級特大地震影響企蹭,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜智末,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一谅摄、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧系馆,春花似錦送漠、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至尼酿,卻和暖如春爷狈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谓媒。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工淆院, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓土辩,卻偏偏與公主長得像支救,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子拷淘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,802評論 2 345

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