Javascript使用integrity屬性進(jìn)行安全驗(yàn)證
一、script標(biāo)簽引入文件
在html
中,script
標(biāo)簽可以通過src
屬性引入一個js文件,引入的js文件可以是本地的,也可以是遠(yuǎn)程的。
1. 引入本地文件
開發(fā)環(huán)境一般多引入本地js
文件。
<script src="./js/index.js"></script>
2. 引入遠(yuǎn)程文件
部署到線上后,一般會分發(fā)到cdn
,需要引入遠(yuǎn)程文件,
形如:
<script src="https://cdn.xxx.xx/js/index.js"></script>
只是引入遠(yuǎn)程文件存在一個問題,如果對應(yīng)的文件被篡改了,那么可能會對用戶造成影響。雖然cdn
一般都是可靠的,但是不排除受到黑客的攻擊。
在這種情況下,可以通過script
標(biāo)簽的屬性 integrity
來進(jìn)行安全驗(yàn)證。
二、integrity安全驗(yàn)證
integrity
屬性設(shè)置引入js
文件的hash
值,瀏覽器在下載js
文件時候,會對js
文件進(jìn)行hash
計(jì)算,如果一致則正常加載,否則拒絕加載運(yùn)行。
形如:
<script integrity="sha384-oqVuAfXRKap7fdgcCY5uykM6+R9GqQ8K/uxy9rx7HNQlGYl1kPzQho1wx4JwY8wC" src="https://cdn.xxx.xx/js/index.js"></script>
1. 引入vue的cdn資源
例如我們要引入vue的cdn資源:
https://unpkg.com/vue@3.0.5/dist/vue.global.js
可以通過 https://www.srihash.org/ 生成hash值。
integrity生成hash值:
最后將 integrity
的值添加到script標(biāo)簽即可。
<script src="https://unpkg.com/vue@3.0.5/dist/vue.global.js" integrity="sha384-0k9//QJdpmfSdp5IK3oJjOYPfz42f2FE0goMLtK9Vq7aKllvc4Lnz7lHPHiFhvDP" crossorigin="anonymous"> </script>
2. 驗(yàn)證是否正常
因?yàn)橐氲氖?code>cdn資源,無法直接修改,但是修改 integrity
的值,如果修改了 integrity
的值,
最終瀏覽器會報(bào)如下錯誤:
Failed to find a valid digest in the 'integrity' attribute for resource 'https://unpkg.com/vue@3.0.5/dist/vue.global.js' with computed SHA-256 integrity 'Wr5PnkpmZ3oQFRZLfDrI6fsePSMak5h8rW2rqq+mdWg='. The resource has been blocked.
意思就是cdn
文件的hash
值和 integrity
的不匹配。
到此這篇關(guān)于Javascript使用integrity屬性進(jìn)行安全驗(yàn)證的文章就介紹到這了,更多相關(guān)script integrity內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
微信小程序 加載 app-service.js 錯誤解決方法
這篇文章主要介紹了微信小程序 加載 app-service.js 錯誤詳解的相關(guān)資料,在開發(fā)微信小程序過程中出現(xiàn)了app-services.js的錯誤,并解決此問題,需要的朋友可以參考下2016-10-10微信小程序 中wx.chooseAddress(OBJECT)實(shí)例詳解
這篇文章主要介紹了微信小程序 中wx.chooseAddress(OBJECT)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-03-03axios?攔截器管理類鏈?zhǔn)秸{(diào)用手寫實(shí)現(xiàn)及原理剖析
這篇文章主要為大家介紹了axios?攔截器管理類鏈?zhǔn)秸{(diào)用手寫實(shí)現(xiàn)及原理剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08瀏覽器切換到其他標(biāo)簽頁或最小化js定時器是否準(zhǔn)時測試
這篇文章主要為大家介紹了瀏覽器切換到其他標(biāo)簽頁或最小化是js定時器是否準(zhǔn)時的測試詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07JavaScript前端學(xué)算法題解LeetCode最大重復(fù)子字符串
這篇文章主要為大家介紹了JavaScript前端學(xué)算法題解LeetCode最大重復(fù)子字符串,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09微信小程序 支付后臺java實(shí)現(xiàn)實(shí)例
這篇文章主要介紹了微信小程序 支付后臺java實(shí)現(xiàn)實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-05-05一文詳解webpack中l(wèi)oader與plugin的區(qū)別
這篇文章主要為大家介紹了一文詳解webpack中l(wèi)oader與plugin的區(qū)別詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02