前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Nginx配置iframe访问

Nginx配置iframe访问

作者头像
华创信息技术
发布2020-05-25 17:14:58
6.9K0
发布2020-05-25 17:14:58
举报
文章被收录于专栏:华创信息技术华创信息技术

文章时间:2020年5月21日 15:24:46 解决问题:内部嵌套的iframe在页面中无法访问

X-Frame-Options响应头配置详解

X-Frame-Options HTTP 响应头是用来给浏览器指示允许一个页面可否在 , 或者 中展现的标记。网站可以使用此功能,来确保自己网站的内容没有被嵌套到别人的网站中去,也从而避免了点击劫持 (clickjacking) 的攻击。

X-Frame-Options三个参数:

1、DENY

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

2、SAMEORIGIN

表示该页面可以在相同域名页面的frame中展示。

3、ALLOW-FROM uri

表示该页面可以在指定来源的frame中展示。

换一句话说,如果设置为DENY,不光在别人的网站frame嵌入时会无法加载,在同域名页面中同样会无法加载。另一方面,如果设置为SAMEORIGIN,那么页面就可以在同域名页面的frame中嵌套。正常情况下我们通常使用SAMEORIGIN参数。

Apache配置

需要把下面这行添加到 'site' 的配置中

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

Nginx配置

需要添加到 ‘http’, ‘server’ 或者 ‘location’ 的配置项中,个人来讲喜欢配置在‘server’ 中

正常情况下都是使用SAMEORIGIN参数,允许同域嵌套

代码语言:javascript
复制
add_header X-Frame-Options SAMEORIGIN;

允许单个域名iframe嵌套

代码语言:javascript
复制
add_header X-Frame-Options ALLOW-FROM http://whsir.com/;

允许多个域名iframe嵌套,注意这里是用逗号分隔

代码语言:javascript
复制
add_header X-Frame-Options "ALLOW-FROM http://hcses.com/,https://hcwdc.com/";

Tomcat配置

在‘conf/web.xml’填加以下配置

代码语言:javascript
复制
<filter>
        <filter-name>httpHeaderSecurity</filter-name>
        <filter-class>org.apache.catalina.filters.HttpHeaderSecurityFilter</filter-class>
        <init-param>
            <param-name>antiClickJackingOption</param-name>
            <param-value>SAMEORIGIN</param-value>
        </init-param>
        <async-supported>true</async-supported>
    </filter>
<filter-mapping>
        <filter-name>httpHeaderSecurity</filter-name>
        <url-pattern>/*</url-pattern>
    <dispatcher>REQUEST</dispatcher>
    <dispatcher>FORWARD</dispatcher>
</filter-mapping>

IIS配置

添加下面的配置到 ‘Web.config’文件中

代码语言:javascript
复制
<system.webServer>
  ...
  <httpProtocol>
    <customHeaders>
      <add name="X-Frame-Options" value="SAMEORIGIN" />
    </customHeaders>
  </httpProtocol>
  ...
</system.webServer>

检查确定是否生效

配置后需要确定X-Frame-Options是否已生效,打开网站按F12键,选择Network,找到对应的Headers。

chrome_A65PidMNoC.png
chrome_A65PidMNoC.png

参考资料

参考教程:https://blog.whsir.com/post-3919.html

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-05-21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • X-Frame-Options响应头配置详解
    • Apache配置
      • Nginx配置
        • Tomcat配置
          • IIS配置
          • 检查确定是否生效
          • 参考资料
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档