Chrome Plugin静态页面触发CSP如何解决CSP

CSP

内容安全策略 (Content Security Policy)
内容安全策略是一种计算机安全标准,旨在防御跨站脚本、点击劫持等代码注入攻击,阻止恶意内容在受信网页环境中执行。
Manifest V3 对于内容安全策略有一些默认的设置,如禁止外部代码的执行,这主要是为了增强安全性。如果需要调整默认策略以允许执行更多类型的资源,可以通过修改 manifest.json 中的 content_security_policy 字段实现。

常见错误:

'content_security_policy.extension_pages': Insecure CSP value "'blob:'" in directive 'script-src'.
Could not load manifest.

解决

此文解决的是 extension_pages 页面不是context 注入

方法1

声明引用文件:【web_accessible_resources -> resources】

	"web_accessible_resources": [
		{
			"resources": [
				"assets/*",
			],
			"matches": [
				"<all_urls>"
			]
		},
		{
			"matches": [
				"<all_urls>"
			],
			"resources": [
				"content.e2b1d2ad.css"
			]
		}
	],

如果是在context: 【content_scripts -> js】

	"content_scripts": [
		{
			"matches": [
				"<all_urls>"
			],
			"js": [
				"content.883ade9e.js"
			],
			"css": []
		}
	],

方法2

如果运行脚本中创建script脚本,需要修改 content_security_policy。如下:
【pages: 页面路径 】

	"content_security_policy": {
		"sandbox": "sandbox allow-scripts allow-modals allow-popups; script-src 'self' 'unsafe-inline' 'unsafe-eval' blob:; object-src 'self';worker-src 'self' blob: ;",
		"extension_pages": "script-src 'self' 'wasm-unsafe-eval'; object-src 'self'; media-src 'self' data: blob: *;"
	},
	"sandbox": {
		"pages": [
			"editor.html",
			"/tabs/download.html"
		]
	}
  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

今天也想MK代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值