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 相关文章推荐
JavaScript面向对象之体会[总结]
Nov 13 Javascript
IE innerHTML,outerHTML所引起的问题
Jun 04 Javascript
js 优化次数过多的循环 考虑到性能问题
Mar 05 Javascript
JS实现漂亮的窗口拖拽效果(可改变大小、最大化、最小化、关闭)
Oct 10 Javascript
javascript图片切换综合实例(循环切换、顺序切换)
Jan 13 Javascript
AngularJS中$interval的用法详解
Feb 02 Javascript
jQuery使用contains过滤器实现精确匹配方法详解
Feb 25 Javascript
Vue.js实现在下拉列表区域外点击即可关闭下拉列表的功能(自定义下拉列表)
May 30 Javascript
使用Angular CLI进行Build(构建)和Serve详解
Mar 24 Javascript
vue打包使用Nginx代理解决跨域问题
Aug 27 Javascript
vue列表单项展开收缩功能之this.$refs的详解
May 05 Javascript
微信小程序8种数据通信的方式小结
Feb 03 Javascript
JavaScript中时间格式化新思路toLocaleString()
Nov 07 #Javascript
JavaScript中isPrototypeOf函数
JavaScript原型链详解
JavaScript组合继承详解
详细聊聊vue中组件的props属性
教你一步步实现一个简易promise
Nov 02 #Javascript
一定要知道的 25 个 Vue 技巧
You might like
PHP 事务处理数据实现代码
2010/05/13 PHP
PHP的MVC模式实现原理分析(一相简单的MVC框架范例)
2014/04/29 PHP
ThinkPHP调用百度翻译类实现在线翻译
2014/06/26 PHP
分享常见的几种页面静态化的方法
2015/01/08 PHP
PHP中CheckBox多选框上传失败的代码写法
2017/02/13 PHP
ThinkPHP框架获取最后一次执行SQL语句及变量调试简单操作示例
2018/06/13 PHP
PHP7 参数处理机制修改
2021/03/09 PHP
TNC vs RR BO3 第一场 2.14
2021/03/10 DOTA
基于jquery实现的树形菜单效果代码
2015/09/06 Javascript
jQuery轮播图实例详解
2018/08/15 jQuery
详解KOA2如何手写中间件(装饰器模式)
2018/10/11 Javascript
webpack开发环境和生产环境的深入理解
2018/11/08 Javascript
深入koa-bodyparser原理解析
2019/01/16 Javascript
详解如何提升JSON.stringify()的性能
2019/06/12 Javascript
vue 组件内获取actions的response方式
2019/11/08 Javascript
extjs图表绘制之条形图实现方法分析
2020/03/06 Javascript
jQuery实现的解析本地 XML 文档操作示例
2020/04/30 jQuery
Python中动态创建类实例的方法
2017/03/24 Python
Python算法之求n个节点不同二叉树个数
2017/10/27 Python
基于Django contrib Comments 评论模块(详解)
2017/12/08 Python
Python爬虫抓取代理IP并检验可用性的实例
2018/05/07 Python
django中模板的html自动转意方法
2018/05/27 Python
python使用多进程的实例详解
2018/09/19 Python
pyqt 实现QlineEdit 输入密码显示成圆点的方法
2019/06/24 Python
Python+OpenCv制作证件图片生成器的操作方法
2019/08/21 Python
Python List列表对象内置方法实例详解
2019/10/22 Python
python实现while循环打印星星的四种形状
2019/11/23 Python
opencv3/python 鼠标响应操作详解
2019/12/11 Python
Django多数据库配置及逆向生成model教程
2020/03/28 Python
Python中免验证跳转到内容页的实例代码
2020/10/23 Python
H5 canvas实现贪吃蛇小游戏
2017/07/28 HTML / CSS
LUISAVIAROMA德国官网:时尚奢侈品牌购物网站
2020/11/12 全球购物
地理科学专业毕业生求职信
2013/10/15 职场文书
企业负责人任命书
2014/06/05 职场文书
求职信的正确写法
2014/07/10 职场文书
党的群众路线教育实践活动学习计划
2014/11/03 职场文书