一、script标签引入文件
在html 中,script 标签可以通过src 属性引入一个js文件,引入的js文件可以是本地的,也可以是远程的。
1. 引入本地文件开发环境一般多引入本地js 文件。 <script src="./js/index.js"></script>
2. 引入远程文件部署到线上后,一般会分发到cdn ,需要引入远程文件, 形如: <script src="https://cdn.xxx.xx/js/index.js"></script> 只是引入远程文件存在一个问题,如果对应的文件被篡改了,那么可能会对用户造成影响。虽然cdn 一般都是可靠的,但是不排除受到黑客的攻击。 在这种情况下,可以通过script 标签的属性 integrity 来进行安全验证。
二、integrity安全验证
integrity 属性设置引入js 文件的hash 值,浏览器在下载js 文件时候,会对js 文件进行hash 计算,如果一致则正常加载,否则拒绝加载运行。
形如: <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标签即可。 <script src="https://unpkg.com/vue@3.0.5/dist/vue.global.js" integrity="sha384-0k9//QJdpmfSdp5IK3oJjOYPfz42f2FE0goMLtK9Vq7aKllvc4Lnz7lHPHiFhvDP" crossorigin="anonymous"></script>
2. 验证是否正常因为引入的是cdn 资源,无法直接修改,但是修改 integrity 的值,如果修改了 integrity 的值, 最终浏览器会报如下错误: 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 的不匹配。 到此这篇关于Javascript使用integrity属性进行安全验证的文章就介绍到这了,更多相关script integrity内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net! 下载地址: JavaScript中时间格式化新思路toLocaleString() Json格式详解 |