欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-06-25 11:20:21
目录一、script标签引入文件1. 引入本地文件2. 引入远程文件二、integrity安全验证1. 引入vue的cdn资源2. 验证是否正常一、script标签引入文件在html中,script标...

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

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

最后将 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内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!