位置: IT常识 - 正文

X-Frame-Options简介(next frame)

编辑:rootadmin
X-Frame-Options简介

推荐整理分享X-Frame-Options简介(next frame),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:frame options,iframe xss,x frame option,fixed frame,framer x,x frame option,frame options,framer x,内容如对您有帮助,希望把文章链接给更多的朋友!

        最近安全检查,发现没有保障和避免自己的网页嵌入到别人的站点里面,于是需要设置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: DENYX-Frame-Options: SAMEORIGIN3、指南

      如果设置为 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"X-Frame-Options简介(next frame)

要将 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 SAMEORIGIN4.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、规范SpecificationHTTP Header Field X-Frame-Options# section-26、浏览器兼容性

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

本文链接地址:https://www.jiuchutong.com/zhishi/295869.html 转载请保留说明!

上一篇:爱丽丝镇附近水域中的柠檬鲨宝宝,巴哈马比米尼岛 (© Ken Kiefer 2/Getty Images)(爱丽丝小镇在哪)

下一篇:YOLOV5更换轻量级的backbone:mobilenetV2(yolov5使用)

  • 小规模纳税人起征点和免征额
  • 没有审计报告的上市公司怎么办
  • 残保金滞纳金能抵扣吗
  • 对公账户汇款方式
  • 非房地产企业销售不动产增值税计算
  • 一般纳税人收到普票怎么做分录
  • 企业清算过程中应收应付的处置
  • 包装物押金是含税价格吗
  • 汽车保险费可以抵扣吗
  • 包装成本为产品的百分比
  • 运费开进发票
  • 土地流转承包费拖欠
  • 公司出售厂房的增值税允许抵扣吗
  • 应交城市维护建设税分录怎么做
  • 拿到省级奖有什么用
  • 取得走逃失联企业的异常增值税发票如何处理
  • 委托贷款利息收入怎么开发票
  • 事业单位收到开办费的会计分录
  • 土地使用权评估中的成本法
  • 增值税免税项目和免征增值税的区别
  • 以前年度的费用可以入在当年吗?
  • 公司租的宿舍记什么科目
  • linux使用cp
  • 待抵扣进项税额和待认证进项税额的区别
  • 公司向私人借款利息可以入账吗
  • docker 使用教程
  • fsm32.exe是什么进程 有什么作用 fsm32进程查询
  • 提供劳务收入怎么交税
  • 财务人员如何审核合同
  • 增值税减免后按3%记提税款吗
  • 一般纳税人增值税优惠政策2023
  • 海关专用缴款书认证的步骤和说明
  • iis制作网页
  • uni-app介绍
  • php如何上传1个g以上的文件
  • 定时器计数器实验报告
  • 建设工程项目设计质量控制的内容
  • 手把手教你win7换主板不重装系统的方法
  • html cssjs
  • 《visual c++游戏编程基础》
  • 织梦专题页模板
  • Spring(十五):Spring整合MyBatis的两种方式
  • 织梦cms为什么不维护了
  • 小企业一年需要缴纳多少税
  • 利息收入为什么冲减财务费用
  • 一般纳税人跨月发票怎么作废
  • 建筑企业的收入特点有哪些
  • 小规模增值税纳税人税率
  • 消费税在企业所得税前扣除吗
  • 通行费电子发票进项税额如何填报
  • 暂估入库的账务处理含税吗
  • 植物售卖
  • 收到公众号消息提醒
  • 材料采购发票未到
  • 公司账户的钱怎么合理的转出来
  • 投标保证金怎么记账科目
  • 交易性金融资产包括哪些项目
  • 认证系统维护费可以全额抵扣吗
  • 收付实现制与权责发生制的例题
  • 期间费用包括哪三种
  • 购进农产品直接销售核定扣除
  • mysql数据库技术介绍
  • sqlserver 锁表语句
  • gridview自定义排序
  • mysql sql行转列
  • freebsd 网卡驱动
  • ubuntu 8.04.1 LTS 下的cpu温度监控软件lm-sensors
  • dmidecode 硬盘
  • win10系统怎么设置默认打印机
  • 在Linux系统中安装Anaconda
  • matplotlib pypi
  • java轻松学
  • 【mclin】手把手叫你在Eclipse里添加Android开发功能(附:完整离线版Android_SDK和Android_ADT下载)
  • 详解Python装饰器由浅入深
  • 结婚日课实例讲解
  • js特殊字符有哪些
  • 国税账户密码在哪里能找到
  • 电子税务局怎么删除办税员
  • 河南税务公众号缴费养老保险
  • 陕西陉阳县税务局官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设