手把手教你Nginx防护 CSP 内容安全策略之base-uri

Somnus_小凯 社区管理
全栈领域优质创作者
博客专家认证
2022-08-18 14:23:14

HTTP Content-Security-Policy base-uri指令限制可以在文档<base>元素中使用的URL 。如果此值不存在,则允许使用任何URI。如果此指令不存在,则用户代理将使用该<base>元素中的值。

CSP版本

2

指令类型

Document指令

默认-src后备

不可以。

句法

基地政策可以允许一个或多个来源:

Content-Security-Policy: base-uri <source>;
Content-Security-Policy: base-uri <source> <source>;

来源

<source>可以是以下之一:

通过名称或IP地址的<host-source> Internet 主机,以及可选的 URL方案 and/or 端口号。该站点的地址可能包含一个可选的前导通配符(星号字符'*'),并且可以使用通配符(再次'*')作为端口号,表示所有合法端口对于源都有效。

示例:

  • http://*.example.com:匹配使用http:URL方案从 example.com 的任何子域加载的所有尝试。
  • mail.example.com:443:匹配所有尝试访问 mail.example.com 上的端口443的尝试。
  • https://store.example.com:匹配所有尝试访问 store.example.com 使用https:

<scheme-source>一种模式,如'http:' 或 'https:'。冒号是必需的,不应使用单引号。您也可以指定数据模式(不推荐)。

  • data:允许将data:URI用作内容源。这是不安全的; 攻击者也可以注入任意数据:URI。谨慎使用这一点,绝对不适用于脚本。

'self'指受保护文档的来源,包括相同的URL方案和端口号。你必须包括单引号。一些浏览器特别排除blobfilesystem从源指令。需要允许这些内容类型的网站可以使用Data属性来指定它们。

'unsafe-inline'允许使用内联资源,如内联<script>元素,javascript:URL,内联事件处理程序和内联<style>元素。你必须包括单引号。

'unsafe-eval'允许使用eval()和类似的方法从字符串创建代码。你必须包括单引号。

'none'指空集;也就是说,没有URL匹配。单引号是必需的。

'nonce- <base64-value>'使用加密随机数(使用一次的数字)的特定内联脚本的白名单。每次发送策略时,服务器都必须生成唯一的随机数值。提供一个无法猜测的随机数是非常重要的,因为绕过资源的策略是微不足道的。例如,查看不安全的内联脚本。

<hash-source>内联脚本或样式的sha256,sha384或sha512。生成散列时,不要包含<script>或<style>标记,并注意大小写和空白字符,包括前导或尾随空格。请参阅不安全的内联脚本。

“strict-dynamic”strict-dynamic源表达式指定显式给予标记中存在的脚本的信任,通过附加一个随机数或散列值,应该传播给由该脚本加载的所有脚本。与此同时,任何白名单或源表达式(例如'self''unsafe-inline'将被忽略)。有关示例,请参阅script-src。

示例

元标签配置

<meta http-equiv="Content-Security-Policy" content="base-uri 'self'">

Apache配置

<IfModule mod_headers.c> 
Header set Content-Security-Policy "base-uri 'self';
</IfModule>

Nginx配置

add_header Content-Security-Policy "base-uri 'self';"

复制

违规示例

鉴于你的域不是 example.com,使用<base>href设置为 example.com 的元素将导致CSP违规。

<meta http-equiv="Content-Security-Policy" content="base-uri 'self'">
<base href="http://example.com/">

// Error: Refused to set the document's base URI to 'http://example.com/' 
// because it violates the following Content Security Policy 
// directive: "base-uri 'self'"

 

规范

规范

状态

评论

内容安全策略级别3该规范中'base-uri'的定义。

编辑草稿

没有变化。

内容安全策略级别2在该规范中的'base-uri'的定义。

建议

初始定义。

...全文
1163 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

31,133

社区成员

发帖
与我相关
我的任务
社区描述
永远相信美好的事情,即将发生
spring cloudspring bootspring 个人社区 山东省·济南市
社区管理员
  • Somnus_小凯
  • 18岁程序员想打职业
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧