Javascript使用integrity属性进行安全验证


Posted in Javascript onNovember 07, 2021

一、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>

二、示例

3. 引入vue的cdn资源

例如我们要引入vue的cdn资源:

https://unpkg.com/vue@3.0.5/dist/vue.global.js

可以通过 https://www.srihash.org/ 生成hash值。

integrity生成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>

4. 验证是否正常

因为引入的是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 相关文章推荐
js的闭包的一个示例说明
Nov 18 Javascript
Jquery+CSS3实现一款简洁大气带滑动效果的弹出层
May 15 Javascript
js 处理数组重复元素示例代码
Dec 27 Javascript
用JavaScript显示浏览器客户端信息的超相近教程
Jun 18 Javascript
jQuery实现表单步骤流程导航代码分享
Aug 28 Javascript
探讨JavaScript标签位置的存放与功能有无关系
Jan 15 Javascript
AngularJS中的$watch(),$digest()和$apply()区分
Apr 04 Javascript
vue2.0实现导航菜单切换效果
May 08 Javascript
详解jQuery同步Ajax带来的UI线程阻塞问题及解决办法
Aug 09 jQuery
基于vue+canvas的excel-like组件实例详解
Nov 28 Javascript
详解在create-react-app使用less与antd按需加载
Dec 06 Javascript
基于vue.js组件实现分页效果
Dec 29 Javascript
JavaScript中时间格式化新思路toLocaleString()
Nov 07 #Javascript
JavaScript中isPrototypeOf函数
JavaScript原型链详解
JavaScript组合继承详解
详细聊聊vue中组件的props属性
教你一步步实现一个简易promise
Nov 02 #Javascript
一定要知道的 25 个 Vue 技巧
You might like
解析php mysql 事务处理回滚操作(附实例)
2013/08/05 PHP
PHP也能干大事 随机函数
2015/04/14 PHP
YII Framework框架教程之使用YIIC快速创建YII应用详解
2016/03/15 PHP
Thinkphp自定义生成缩略图尺寸的方法
2019/08/05 PHP
php策略模式简单示例分析【区别于工厂模式】
2019/09/25 PHP
PHP实现15位身份证号转18位的方法分析
2019/10/16 PHP
javascript tips提示框组件实现代码
2010/11/19 Javascript
JavaScript删除数组元素的方法
2015/03/20 Javascript
Angular2利用组件与指令实现图片轮播组件
2017/03/27 Javascript
Angular.js实现动态加载组件详解
2017/05/28 Javascript
使用puppeteer破解极验的滑动验证码
2018/02/24 Javascript
原生js实现淘宝放大镜效果
2020/10/28 Javascript
动态内存分配导致影响Javascript性能的问题
2018/12/18 Javascript
vue 关闭浏览器窗口的时候,清空localStorage的数据示例
2019/11/06 Javascript
[00:12]2018DOTA2亚洲邀请赛SOLO赛 MidOne是否中单第一人?
2018/04/05 DOTA
[02:38]2018年度DOTA2最佳劣单位选手-完美盛典
2018/12/17 DOTA
总结用Pdb库调试Python的方式及常用的命令
2016/08/18 Python
Python批量查询域名是否被注册过
2017/06/21 Python
python 上下文管理器使用方法小结
2017/10/10 Python
基于Python log 的正确打开方式
2018/04/28 Python
Python参数解析模块sys、getopt、argparse使用与对比分析
2019/04/02 Python
Python使用matplotlib绘制三维参数曲线操作示例
2019/09/10 Python
Python 读取xml数据,cv2裁剪图片实例
2020/03/10 Python
CSS3中使用RGBa来调节透明度的教程
2016/05/09 HTML / CSS
使用phonegap创建联系人的实现方法
2017/03/30 HTML / CSS
Free People中国官网:波西米亚风格女装服饰
2016/08/30 全球购物
德国家用电器购物网站:Premiumshop24
2019/08/22 全球购物
公益广告语集锦
2014/03/13 职场文书
毕业生学校推荐信范文
2014/05/21 职场文书
社区助残日活动总结
2014/08/29 职场文书
活动总结结尾怎么写
2014/08/30 职场文书
怎样写离婚协议书
2014/09/10 职场文书
2014年学校体育工作总结
2014/12/08 职场文书
汇报材料怎么写
2014/12/30 职场文书
换届选举主持词
2015/07/03 职场文书
Java实现HTML转为Word的示例代码
2022/06/28 Java/Android