前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >跟我一起探索HTTP-X-Frame-Options

跟我一起探索HTTP-X-Frame-Options

作者头像
用户1418987
发布2023-10-16 09:34:57
4190
发布2023-10-16 09:34:57
举报
文章被收录于专栏:coder

X-Frame-Options

跟我一起探索HTTP-X-Frame-Options_HTTP
跟我一起探索HTTP-X-Frame-Options_HTTP

仅当访问文档的用户使用支持 X-Frame-Options 的浏览器时,此附加的安全性才会被提供。

备注: Content-Security-Policy HTTP 响应头有一个 frame-ancestors指令,支持这一指令的浏览器已经废弃了 X-Frame-Options 响应头。

语法

X-Frame-Options 有两个可能的值:

代码语言:javascript
复制
X-Frame-Options: DENY
X-Frame-Options: SAMEORIGIN
指南

如果设置为 DENY,不光在别人的网站 frame 嵌入时会无法加载,在同域名页面中同样会无法加载。另一方面,如果设置为 SAMEORIGIN,那么页面就可以在同域名页面的 frame 中嵌套。

  • DENY表示该页面不允许在 frame 中展示,即便是在相同域名的页面中嵌套也不允许。
  • SAMEORIGIN表示该页面可以在相同域名页面的 frame 中展示。规范让浏览器厂商决定此选项是否应用于顶层、父级或整个链,有人认为该选项不是很有用,除非所有的祖先页面都属于同一来源(origin)。参见浏览器兼容性以获取详细的兼容性信息。
  • ALLOW-FROM uri 已弃用 这是一个被弃用的指令,不再适用于现代浏览器,请不要使用它。在支持旧版浏览器时,页面可以在指定来源的 frame 中展示。请注意,在旧版 Firefox 上,它会遇到与 SAMEORIGIN 相同的问题——它不会检查 frame 所有的祖先页面来确定他们是否是同一来源。Content-Security-Policy HTTP 首部有一个 frame-ancestors 指令,你可以使用这一指令来代替。

示例

备注: 使用 meta 标签来设置 X-Frame-Options 是无效的!例如 <meta http-equiv="X-Frame-Options" content="deny"> 没有任何效果。不要这样用!只有当像下面示例那样设置 HTTP 头 X-Frame-Options 才会生效。

配置 Apache

配置 Apache 在所有页面上发送 X-Frame-Options 响应头,需要把下面这行添加到 'site' 的配置中:

代码语言:javascript
复制
Header always set X-Frame-Options "SAMEORIGIN"

要将 Apache 的配置 X-Frame-Options 设置成 DENY,按如下配置去设置你的站点:

代码语言:javascript
复制
Header set X-Frame-Options "DENY"
配置 Nginx
跟我一起探索HTTP-X-Frame-Options_响应头_02
跟我一起探索HTTP-X-Frame-Options_响应头_02

配置 Nginx 发送 X-Frame-Options 响应头,把下面这行添加到 'http', 'server' 或者 'location' 的配置中:

代码语言:javascript
复制
add_header X-Frame-Options SAMEORIGIN always;
配置 IIS
跟我一起探索HTTP-X-Frame-Options_Apache_03
跟我一起探索HTTP-X-Frame-Options_Apache_03

配置 IIS 发送 X-Frame-Options 响应头,添加下面的配置到 Web.config 文件中:

代码语言:javascript
复制
<system.webServer>
  ...

  <httpProtocol>
    <customHeaders>
      <add name="X-Frame-Options" value="SAMEORIGIN" />
    </customHeaders>
  </httpProtocol>

  ...
</system.webServer>
配置 HAProxy
跟我一起探索HTTP-X-Frame-Options_HTTP_04
跟我一起探索HTTP-X-Frame-Options_HTTP_04

配置 HAProxy 发送 X-Frame-Options 响应头,添加这些到你的前端、监听(listen),或者后端的配置里面:

代码语言:javascript
复制
rspadd X-Frame-Options:\ SAMEORIGIN

或者,在较新的版本中:

代码语言:javascript
复制
http-response set-header X-Frame-Options SAMEORIGIN
配置 Express
跟我一起探索HTTP-X-Frame-Options_响应头_05
跟我一起探索HTTP-X-Frame-Options_响应头_05

要配置 Express 以发送 X-Frame-Options 响应头,你可以使用借助了frameguardhelmet来设置首部。在你的服务器配置里面添加:

代码语言:javascript
复制
const helmet = require('helmet');
const app = express();
app.use(helmet.frameguard({ action: 'SAMEORIGIN' }));

或者,你也可以直接用 frameguard:

代码语言:javascript
复制
const frameguard = require('frameguard')
app.use(frameguard({ action: 'SAMEORIGIN' }))
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-05-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 语法
    • 指南
    • 示例
      • 配置 Apache
        • 配置 Nginx
          • 配置 IIS
            • 配置 HAProxy
              • 配置 Express
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档