首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SRI散列的最佳大小是多少?

SRI(Subresource Integrity)散列是一种安全特性,用于确保网页上加载的外部资源(如脚本、样式表或字体文件)未被篡改。SRI通过在HTML标签中包含一个散列值来实现这一点,浏览器在加载资源时会计算资源的散列值并与提供的散列值进行比较,如果不匹配则不会加载该资源。

SRI散列的最佳大小

SRI散列的大小取决于所使用的散列算法。常见的散列算法包括SHA-256、SHA-384和SHA-512。以下是这些算法的散列大小:

  • SHA-256:256位(32字节)
  • SHA-384:384位(48字节)
  • SHA-512:512位(64字节)

优势

  1. 安全性:SRI散列可以有效防止第三方篡改网页资源,提高网站的安全性。
  2. 完整性验证:通过散列值的比较,确保加载的资源未被修改。
  3. 灵活性:可以应用于各种外部资源,如JavaScript文件、CSS文件、字体文件等。

类型

SRI散列主要有以下几种类型:

  1. SHA-256:适用于大多数情况,提供较高的安全性和性能。
  2. SHA-384:提供更高的安全性,适用于对安全性要求较高的场景。
  3. SHA-512:提供最高级别的安全性,适用于对安全性要求极高的场景。

应用场景

SRI散列广泛应用于需要确保资源完整性的场景,例如:

  • 内容分发网络(CDN):确保从CDN加载的资源未被篡改。
  • 第三方库:确保加载的第三方JavaScript库或CSS文件未被修改。
  • 字体文件:确保加载的字体文件未被篡改,防止字体攻击。

常见问题及解决方法

为什么SRI散列会失败?

  1. 资源被篡改:如果资源在传输过程中被篡改,散列值将不匹配。
  2. 散列算法不匹配:使用的散列算法与生成散列值时使用的算法不一致。
  3. 资源路径错误:资源路径不正确,导致加载的资源与预期不符。

如何解决这些问题?

  1. 确保资源未被篡改:使用可靠的CDN或服务器,确保资源在传输过程中未被篡改。
  2. 使用一致的散列算法:确保生成散列值时使用的算法与HTML标签中指定的算法一致。
  3. 检查资源路径:确保资源路径正确,避免加载错误的资源。

示例代码

以下是一个使用SHA-256算法的SRI散列示例:

代码语言:txt
复制
<script src="https://example.com/example-framework.js"
        integrity="sha256-1234567890abcdef1234567890abcdef1234567890abcdef1234567890abcdef"
        crossorigin="anonymous"></script>

在这个示例中,integrity属性包含了资源的SHA-256散列值。

参考链接

通过以上信息,您可以更好地理解SRI散列的最佳大小、优势、类型、应用场景以及常见问题的解决方法。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

分离链接代码实现

列为一种用于以常数平均时间执行插入,删除和查找技术。一般实现方法是使通过数据关键字可以计算出该数据所在位置,类似于Python中字典。...关于需要解决以下问题: 关键字如何映射为一个数(索引)——函数 当两个关键字函数结果相同时,如何解决——冲突 函数 函数为关键字->索引函数,常用关键字为字符串,则需要一个字符串...->整数映射关系,常见三种函数为: ASCII码累加(简单) 计算前三个字符加权和$\sum key[i] * 27^{i}$ (不太好,3个字母常用组合远远小于可能组合) 计算所有字符加权和并对长度取余...,发生冲突,本次使用分离链接法解决: 每个数据结构有一个指针可以指向下一个数据,因此列表可以看成链表头集合 当插入时,将数据插入在对应链表中 访问时,遍历对应链表,直到找到关键字...,因此需要定义一个节点用于计算值 point := h.table[temp.hash].next for point !

1.5K80

基本概念

大家好,又见面了,我是你们朋友全栈君。 基本概念 什么是?为什么需要是一种思想。...——你根本不用去回想我家地址是多少,你知道它就在那里,就在家这个词刚刚出现在你脑海中时候。...这就是人类需要原因,你无法不被如此诱惑所吸引。 完美 在时间与空间性能上均达到完美的,称为完美。...设列表大小为 M M M,此时,从定义域 [ 0 , R ) [0, R) [0,R)到值域 [ 0 , M ) [0, M) [0,M)映射不可能是单射,即不可避免地会出现不同关键码映射到列表中同一个位置...独立链法(separate chaining) 多槽位法所面临问题,其实就是类似于数组这种静态数据结构所面临问题,即在实际应用之前,你不会清楚数组大小应该划分到多大。

1.4K20
  • Python对象

    这里先介绍Python语言中对象。 函数 在介绍列表以及它在Python中实现之前,先简要说明函数及其工作原理。...函数是一种可以将任何长度数据映射到固定长度函数,这个映射过程称为(hash)。 函数具有以下三个特点: 计算速度快:计算一条数据值,必须要快。...确定性:相同字符串值总相同。 值长度固定:无论输入是1个字节、10个字节还是1万个字节,生成值始终是固定预定长度。...Python内置函数 Python内置函数hash()是一个函数,它能够返回输入对象十进制整数形式值。...像上述示例这样,-1和-2值相同,称为碰撞(collision),即两个对象值产生了冲突。 以上示例中,都是以数字作为hash()参数,如果改用字符串,返回也是整数形式值。

    5K20

    UDPTCP 包大小限制是多少

    在应用程序中我们用到 Data 长度最大是多少,直接取决于底层限制,即:MTU 以太网(Ethernet) 数据帧 在链路层   IP包 在网络层   TCP或UDP包 在传输层   TCP或UDP...我们往下看 2>、最佳推导: a>、按最大值来推算: IP 数据包按最大值 65535字节 来算,假设我们现在带宽是:100Mbps,因为以太网帧是传输中最小可识别单元,再往下就是0101所对应光信号了...二、计算 udp 或 tcp 包最佳大小: img 从上图可知:本地 MTU 值 = 1500,那么: UDP 包大小: 1500 - IP头(20) - UDP头(8) = 1472(Bytes...MTU 四、如何测出当前网络最佳MTU值 1、首先,我们必须明白什么才是最佳 MTU 值。...大部分操作系统会提供给用户一个默认值,该值一般对用户是比较合适。 3、怎样才能知道自己的当前网络环境 MTU 值是多少呢? 下面便来介绍测试方法。

    4.8K30

    PHP密码算法学习

    PHP密码算法学习 不知道大家有没有看过 Laravel 源码。在 Laravel 源码中,对于用户密码加密,使用是 password_hash() 这个函数。...这个函数是属于 PHP 密码算法扩展中所包含函数,它是集成在 PHP 源码中扩展,并且还是 PHP 官方所推荐一种密码加密方式。那么它有什么好处呢?...查看密码函数加密算法 首先,我们还是看看当前环境中所支持 password_hash() 算法。...我们简单了解一下即可。 使用密码函数加密数据 重点还是在这个加密函数应用上,我们就来看看 password_hash() 这个函数使用。...请注意上面的测试代码,我们两段代码明文是一样,但是加密出来密码可是完全不相同哦。当然,更重要是,这个加密后密码也是不可反解码,是一个正规单向 Hash

    1.3K10

    Redis中类型详解

    在Redis中,Hash是一种存储键值对数据结构,它适用于存储对象多个属性。Jedis作为Java开发者与Redis交互工具,提供了丰富API来操作Hash类型。...本文将深入介绍Jedis如何操作Redis中Hash类型数据,通过生动代码示例和详细解释,助你轻松掌握Jedis中Hash各种操作。Jedis中Hash基本操作1....存储多个字段数据可以使用HMSET命令一次性设置多个字段值,在Jedis中,对应方法是hmset:// 一次性存储多个字段值Map fieldValues = new...中Hash类型数据。...希望通过学习本文,你对Jedis中Hash操作有了更深入理解,并能够灵活运用在你项目中。在实际开发中,充分发挥Jedis优势,将有助于提升系统性能和代码质量。

    24320

    Python:说说字典和列表,冲突解决原理

    在 dict 列表当中,每个键值对都占用一个表元,每个表元都有两个部分,一个是对键引用,一个是对值引用。因为每个表元大小一致,所以可以通过偏移量来读取某个表元。...Python会设法保证大概还有三分之一表元是空,当快要达到这个阀值时候,会进行扩容,将原列表复制到一个更大列表里。 如果要把一个对象放入到列表里,就先要计算这个元素键值。...这就要求键(key)必须是可。 一个可对象必须满足以下条件: 支持 hash() 函数,并且通过 __hash__() 方法所得到值是不变。...,把这个值最低几位数字当作偏移量,在列表里查找表元(具体取几位,得看当前列表大小)。...为了解决冲突,算法会在值中另外再取几位,然后用特殊方法处理一下,把得到新数值作为偏移量在列表中查找表元,若找到表元是空,则同样抛出 KeyError 异常;若非空,则比较键是否一致,一致则返回对应

    2K30

    【C++进阶】哈希表开和闭模拟实现(附源码)

    这里和开解决哈希冲突方法都是除留余数法。...一些哈希函数:字符串哈希算法 一.闭 概念 闭:也叫开放定址法,当发生哈希冲突时,如果哈希表未被装满,说明在哈希表中必然还有 空位置,那么可以把key存放到冲突位置中“下一个” 空位置中去。..._table.swap(_table); } private: vector _table; size_t _n; //负载因子 }; } 二.开 概念 开就是我们平时说哈希桶...开:又叫链地址法(开链法) 首先对关键码集合用函数计算地址,具有相同地址关键码归于同一子集合,每一个子集合称为一个桶,各个桶中元素通过一个单链表链接起来,各链表头结点存储在哈希表中。...即开每一个位置挂着一个单链表,这个单链表称为桶,每个桶里放都是冲突数据。

    15510

    以太坊合约交易大小上限是多少

    在以太坊上发送交易,最多能包含多少字节数据?有没有上限? 理论上在以太坊中,对交易大小或者块大小都没有直接或固定上限,这也是 以太坊一个优势。...不过这并不意味着交易能携带数据量大小没有上限,因为一个块可以使用 gas是有上限。 在写这篇文章时,ethstats显示 这个值是7,984,452,大约700万。...因此,理论上我们可以创建一个交易,让它消耗掉一个块能用全部gas,这就 决定了一个交易理论上可以包含最多数据。...决定数据大小另一个因素是数据内容,因为不同数据消耗gas也不同: 0字节消耗4个gas 非0字节消耗68个gas 每个交易要支付21000个gas 利用块gas上限,并结合你数据内容,就可以计算出一个交易能发送数据大小了...接下来,以太坊可扩展性开始展示它力量了。 如果你希望马上开始学习以太坊DApp开发,可以访问汇智网提供出色在线互动教程: 以太坊DApp实战开发入门 去中心化电商DApp实战开发

    2.1K50

    Jedis 操作 Hash:Redis中类型

    在Redis中,Hash是一种存储键值对数据结构,它适用于存储对象多个属性。Jedis作为Java开发者与Redis交互工具,提供了丰富API来操作Hash类型。...本文将深入介绍Jedis如何操作Redis中Hash类型数据,通过生动代码示例和详细解释,助你轻松掌握Jedis中Hash各种操作。Jedis中Hash基本操作1....存储多个字段数据可以使用HMSET命令一次性设置多个字段值,在Jedis中,对应方法是hmset:// 一次性存储多个字段值Map fieldValues = new...中Hash类型数据。...希望通过学习本文,你对Jedis中Hash操作有了更深入理解,并能够灵活运用在你项目中。在实际开发中,充分发挥Jedis优势,将有助于提升系统性能和代码质量。

    25610

    搜索引擎中URL

    (hash)也就是哈希,是信息存储和查询所用一项基本技术。在搜索引擎中网络爬虫在抓取网页时为了对网页进行有效地排重必须对URL进行,这样才能快速地排除已经抓取过网页。...虽然google、百度都是采用分布式机群进行哈希排重,但实际上也是做不到所有的网页都分配一个唯一地址。但是可以通过多级哈希来尽可能地解决,但却要会出时间代价在解决哈希冲突问题。...所以这是一个空间和时间相互制约问题,我们知道哈希地址空间如果足够大可以大大减少冲突次数,所以可以通过多台机器将哈希表根据一定特征局部化,分散开来,每一台机器都是管理一个局部地址。   ...所以我可以将原始URL进行一次标准化处理后再做哈希这样就会有很大改善,本人通过大量实验发现先对URL进行一次MD5加密,然后再对加密后这个串再哈希这样大大提高了哈希效率。...而采用MD5再哈希方法明显对地址起到了一个均匀发布作用。

    1.7K30

    【C++】哈希表 --- 闭版本实现

    解决哈希冲突两种常见方法是:闭和开 2.3 开与闭 该方式即为哈希()方法,哈希方法中使用转换函数称为哈希()函数,构造出来结构称为哈希表(Hash Table)(或者称列表...) 列表分为闭和开,这是两种完全不同方式,但是底层都是数组: 闭:也叫开放定址法,当发生哈希冲突时,如果哈希表未被装满,说明在哈希表中必然还有空位置,那么可以把key存放到冲突位置中...开:开又叫链地址法(开链法),首先对关键码集合用函数计算地址,具有相同地址关键码归于同一子集合,每一个子集合称为一个桶,各个桶中元素通过一个单链表链起来,各链表头结点存储在哈希表中...3 闭版本实现 下面我们来实现闭版本哈希表 3.1 框架搭建 首先我们需要进行一个简单框架搭建: 我们需要一个HashData类,来储存数据 HashTable类底层是vector容器...因为会有不同类型key,所以我们需要一个仿函数来将不同类型转换为size_t; 因为闭删除不能直接删除节点,否则会导致线性探测失效,所以HashData类里需要记录状态!

    9810

    关于哈希()函数你应该知道东西

    无论安全从业人员用计算机做什么,有一种工具对他们每个人都很有用:加密 哈希()(hash)函数。...对于任意模式输入,给定哈希函数输出(“哈希值”)长度都是一样(对于 SHA-256,是 32 字节或者 256 比特,这从名字中就能看出来)。...没有了唯一性,这个技术就没用了,至少就通常目的而言是这样。 如果两个不同输入产生了相同输出,那么这样哈希过程就称作“ 碰撞(collision)”。...直接比较二进制数据是非常缓慢且计算量巨大,但是哈希函数在设计上非常快。给定两个大小为几 M 或者几 G 文件,你可以事先生成它们哈希值,然后在需要时候再进行比较。...事实上,这些性质还有更技术性名称,我上面所描述将三个重要属性混在了一起。

    93720

    【C++】哈希表 ---开版本实现

    我们可以通过对key值处理快速找到目标。如果多个key出现相同映射位置,此时就发生了哈希冲突,就要进行特殊处理:闭和开。...闭:也叫做开放定址法,其核心是出现哈希冲突,就从发生冲突位置开始,依次向后探测,直到寻找到下一个空位置为止。...开:又叫链地址法(开链法),其核心是每个位置是以链表结构储存,遇到哈希冲突就将数据进行头插。 我们已经实现了闭版本哈希表,今天我们来实现开版本哈希表(哈希桶)!...2 开版本实现 我们先来分析一下,我们要实现哈希桶需要做些什么工作。开本质上是一个数组,每个位置对于了一个映射地址。开解决哈希冲突本质是将多个元素以链表进行链接,方便我们进行寻找。...{ size_t key = 0; for (auto s : k) { key *= 131; key += s; } return key; } }; //开哈希表

    12510

    PHP中密码安全性分析

    本文实例讲述了PHP中密码安全性。分享给大家供大家参考,具体如下: php基本哈希函数已经不再安全?...,哈希之后结果是一样,对于一些简单明文,是可以通过遍历,然后对照加密之后密文得到明文。...网上有流传“彩虹表”,就是遍历一个非常大数据库,存储了明文和密文对照关系,通过查询就能得到密文对应明文。...上面我们对所有的密码都使用同样盐,这中方式是不大安全。比如,张三和李四密码是一样,则存储在数据库中密文也是一样,这无疑让黑客更容易破解了。...在线加密工具: http://tools.zalou.cn/password/CreateMD5Password 在线/哈希算法加密工具: http://tools.zalou.cn/password

    1.4K30
    领券