关于 Web Content-Security-Policy Directive 通过 meta 元素指定的一些测试用例
data:image/s3,"s3://crabby-images/72a96/72a96f78638c5df7137537b2c315822a3b3e447d" alt="关于 Web Content-Security-Policy Directive 通过 meta 元素指定的一些测试用例"
Content Security Policy 是一种使用标题或 meta 元素来限制或批准加载到指定网站上的内容的策略。 这是一个广受支持的安全标准,所有网站运营者都应该对这些标准了然于心。
使用 CSP 通过说明允许或不允许的规则为 Web 网站增加了一层保护。 这些规则有助于防御内容注入和跨站点脚本 (XSS) 攻击,这是 OWASP 的十大 Web 应用程序安全风险中的两个。
当攻击者能够通过注入恶意代码来破坏未受保护的网站时,就会发生 XSS 攻击。 当用户尝试与站点交互时,恶意脚本会在用户的浏览器中执行,从而使攻击者能够访问受害者与站点的交互,例如登录信息等。
CSP 将阻止大多数脚本注入攻击的发生,因为它可以设置为将 JavaScript 限制为仅从受信任的位置加载。
本文介绍一些基于 frame-src
这个 Directive 的各种测试用例。作为容器,定义 iframe 的 web 应用,监听在 3000 端口:wechat 文件夹下
data:image/s3,"s3://crabby-images/1a74c/1a74c831785f8485c2ed708a48e74559b8cb35db" alt=""
嵌入了另一个网页,监听在 3002 端口,Jerrylist 文件夹下面:
data:image/s3,"s3://crabby-images/8e9ca/8e9ca46d562ad97e9917c4a48ac9b754d67db9be" alt=""
如果 Jerrylist 文件夹下的 csp html 里没有声明任何 csp 相关的 Directive(通过 meta 标签),则 iframe 工作正常:
data:image/s3,"s3://crabby-images/25b10/25b109a57e87f80386cd3e42d53c2dc57d78e873" alt=""
测试 1:3000 应用(即嵌入 3002 应用的 web 应用里)增加 frame-src
源代码:
data:image/s3,"s3://crabby-images/eea2f/eea2f4a103a260b43179735129757c931e422079" alt=""
测试结果:
Refused to frame 'http://localhost:3002/' because it violates the following Content Security Policy directive: "frame-src 'self'".
iframe 加载失败:
data:image/s3,"s3://crabby-images/7d4cb/7d4cbbd7b18e46b21877345e6dd4b8bb4c56828e" alt=""
测试 2
data:image/s3,"s3://crabby-images/f4a71/f4a71fa31a7da5f7cf564419938aeefa46117864" alt=""
错误消息:
The source list for the Content Security Policy directive 'frame-src' contains an invalid source: ''http://localhost:3002''. It will be ignored.11:25:37.549 localhost/:6 Refused to frame 'http://localhost:3002/' because it violates the following Content Security Policy directive: "frame-src 'none'".
iframe 加载失败:
data:image/s3,"s3://crabby-images/9cb14/9cb1497e00a2457dd0082d9a494be7d6622d2663" alt=""
改成 *
的话,又重新工作了:
data:image/s3,"s3://crabby-images/56679/56679cce6c4627e3981c4875be38eec52bf54e63" alt=""
data:image/s3,"s3://crabby-images/20513/205137595e9cdff399ecfd340cbfef787cf5f8b9" alt=""
下列代码也工作:
data:image/s3,"s3://crabby-images/1ee03/1ee035f5d1ed6c5890c3b634321431224a3162cf" alt=""
下列代码也工作:
data:image/s3,"s3://crabby-images/245bf/245bfc30cebfa7f4774f2e5143f5aaa9e6eb6c69" alt=""
data:image/s3,"s3://crabby-images/db1a4/db1a400d6978b9aa5076d500bbd45467ecd7fbd2" alt=""
下列代码也工作:
data:image/s3,"s3://crabby-images/8c48d/8c48d15d291a61e5722e1dbf00fb53bfbdcdb07f" alt=""
版权声明: 本文为 InfoQ 作者【Jerry Wang】的原创文章。
原文链接:【http://xie.infoq.cn/article/23680109628cc4c3207242162】。文章转载请联系作者。
评论