IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> X-Frame-Options简介 -> 正文阅读

[开发测试]X-Frame-Options简介

? ? ? ? 最近安全检查,发现没有保障和避免自己的网页嵌入到别人的站点里面,于是需要设置X-Frame-Options增加安全性。

? ? ? ? 网上查了查资料,这里记录一下。

? ? ? ? 可以使用下面工具进行验证:Clickjacking Tool | Test | UI Redressing

1、X-Frame-Options

? X-Frame-Options?HTTP?响应头是用来给浏览器指示允许一个页面可否在?<frame><iframe><embed>?或者?<object>?中展现的标记。站点可以通过确保网站没有被嵌入到别人的站点里面,从而避免点击劫持攻击。

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

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

首部类型响应首部
禁止修改的消息首部

2、语法

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

X-Frame-Options: DENY
X-Frame-Options: SAMEORIGIN

3、指南

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

DENY

? ? ? 表示该页面不允许在 frame 中展示,即便是在相同域名的页面中嵌套也不允许。

SAMEORIGIN

? ? ? 表示该页面可以在相同域名页面的 frame 中展示。规范让浏览器厂商决定此选项是否应用于顶层、父级或整个链,有人认为该选项不是很有用,除非所有的祖先页面都属于同一来源(origin)(见?bug?725490)。参见浏览器兼容性以获取详细的兼容性信息。

ALLOW-FROM uri?Deprecated

? ? ? 这是一个被弃用的指令,不再适用于现代浏览器,请不要使用它。在支持旧版浏览器时,页面可以在指定来源的 frame 中展示。请注意,在旧版 Firefox 上,它会遇到与?SAMEORIGIN?相同的问题——它不会检查 frame 所有的祖先页面来确定他们是否是同一来源。Content-Security-Policy?HTTP 首部有一个?frame-ancestors?指令,你可以使用这一指令来代替。

4、示例

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

4.1 配置 Apache

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

Header always set X-Frame-Options "SAMEORIGIN"

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

Header set X-Frame-Options "DENY"

4.2 配置 Nginx

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

add_header X-Frame-Options SAMEORIGIN always;

nginx配置X-Frame-Options有四个参数:

1、DENY
? ? 表示该页面不允许在frame中展示,即便是在相同域名的页面中嵌套也不允许。
? ? nginx配置示例:add_header X-Frame-Options DENY;

2、SAMEORIGIN
? ? 表示该页面可以在相同域名页面的frame中展示。
? ? nginx配置示例:add_header X-Frame-Options SAMEORIGIN;

3、ALLOW-FROM url
? ? 表示该页面可以在指定来源的frame中展示。
? ? nginx配置示例:add_header X-Frame-Options ‘ALLOW-FROM ?https://xxx.xxxxxx.com’;
? ? ‘’引号是必须要写的哦!

4、ALLOWALL
? ? 表示该页面允许全部来源域名的frame展示。
? ? nginx配置示例:add_header X-Frame-Options ALLOWALL;

? ? 有时候我们需要允许多个url的来源,但是又不能全部开放,所以应该匹配第三种方法ALLOW-? FROM url,那么多个url该如何配置呢,百度了所有网站都没有找到,那么这里写给大家,其实很简单:
? ? add_header X-Frame-Options ‘ALLOW-FROM ?https://xxx.xxxxxx.com ?https://xxx2.xxxxxxx.com’;
? ? 就是使用空格隔开就好了!

4.3 配置 IIS

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

<system.webServer>
  ...

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

  ...
</system.webServer>

Copy to Clipboard

参见?Microsoft 关于使用 IIS Manager 来修改这一配置的支持文章用户界面。

4.4 配置 HAProxy

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

rspadd X-Frame-Options:\ SAMEORIGIN

或者,在较新的版本中:

http-response set-header X-Frame-Options SAMEORIGIN

4.5 配置 Express

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

const helmet = require('helmet');
const app = express();
app.use(helmet.frameguard({ action: 'SAMEORIGIN' }));

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

const frameguard = require('frameguard')
app.use(frameguard({ action: 'SAMEORIGIN' }))

5、规范

Specification
HTTP Header Field X-Frame-Options#?section-2

6、浏览器兼容性

Report problems with this compatibility data on GitHub

7、验证

?可以使用下面工具进行验证:Clickjacking Tool | Test | UI Redressing

8、参考

X-Frame-Options - HTTP | MDN

Clickjacking Tool | Test | UI Redressing

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2022-05-09 13:03:57  更:2022-05-09 13:04:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/17 22:43:52-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码