子资源完整性(SRI)支持

NOTE
Adobe Experience Platform Launch已更名为Adobe Experience Platform中的一套数据收集技术。 因此,产品文档中的术语有一些改动。 有关术语更改的综合参考,请参阅以下文档

本文档介绍Adobe Experience Platform如何支持子资源完整性(SRI)。

现代网站是通过引用 Web 上不同位置的图像、内容和脚本来构建的。SRI允许浏览器验证请求文件的内容是否未被意外修改。

虽然 SRI 与内容安全策略 (CSP) 的用例是互补的,但是 SRI 不同于 CSP,CSP 可确保网站上仅允许使用来自可信来源的文件。而 SRI 则更进一步,它可确保这些文件的内容符合您的预期。

NOTE
有关 SRI 的更多详细信息,请参阅 MDN Web 文档

SRI 验证过程可概括如下:

  1. 您生成要验证的资产的加密哈希。
  2. 您将哈希放置在网站上用于加载文件的 HTML 元素的 integrity 属性中。
  3. 当浏览器发现 integrity 属性时,浏览器会请求资源,并独立生成自己的加密哈希版本。
  4. 浏览器将 integrity 哈希与它生成的哈希进行比较。如果二者匹配,则允许使用资产。如果二者不匹配,则将阻止使用资产。

标记管理系统的限制

作为一款标记管理系统(TMS),Adobe Experience Platform中的标记提供了一个编译的JavaScript库内部版本,您可以通过单个<script>元素(嵌入代码)将该内部版本加载到页面上。 TMS 提供的动态功能是通过动态交换该脚本的内容来实现的,无需更改其他任何内容。

但是,如果脚本内容发生更改,这些内容的加密哈希也会随之更改。因此,要搭配使用 SRI 与 TMS 的唯一方法是,在发布新内部版本的同时更新嵌入代码。对于许多人来说,这首先就违背了使用 TMS 的主要目的。

标记的另一个最佳安全选项是实施内容安全策略。 有关详细信息,请参阅CSP和标记的指南。

将 SRI 集成到内部版本部署中

如果您仍然希望将 SRI 用于库内部版本,则必须使用自托管。如果您使用 Adobe 管理的主机,则在没有足够的时间且新内部版本内容与嵌入代码的 integrity 属性不匹配的情况下,无法使用 SRI。

自动完成嵌入代码更新流程的复杂程度因网站结构而异,但一般步骤可概括如下:

  1. 通过 SFTP 交付或从用户界面下载存档来检索生产库内部版本。
  2. 生成主内部版本的加密哈希。
  3. 确保将嵌入代码的 integrity 属性更新为新哈希,并将引用的内部版本作为同一部署的一部分进行更新。
IMPORTANT
此方法仅适用于主内部版本。它不包含任何可能存在的较小文件。

后续步骤

本文档介绍了将SRI与标记一起使用的限制,以及在存在这些限制的情况下,将SRI集成到库内部版本部署中所需的步骤。 如果您尚未阅读有关CSP和标记的指南,强烈建议您参阅其中所述的替代安全选项。

recommendation-more-help
12b4e4a9-5028-4d88-8ce6-64a580811743