解决iframe嵌套第三方网址不能访问

码农Davi 2024-06-24 13:33:03 阅读 76

第一种报错描述:

Refused to display '嵌套的网址' in a frame because it set 'X-Frame-Options' to 'sameorigin'.

关于X-Frame-Options:

X-Frame-Options 是一个 HTTP 响应头部,用于防止网站被嵌入到其他网站的 iframe 中。该协议定义了一些选项,使网站可以控制在哪些网站中可以嵌入自己的内容,从而防止网站被点击劫持攻击。

X-Frame-Options 协议有三种选项:

1.DENY:拒绝所有网站嵌入。

2.SAMEORIGIN:只允许同源网站嵌入。

3.ALLOW-FROM uri:允许指定的 URI 嵌入。

如果网站设置了 X-Frame-Options 响应头部,浏览器会根据该选项来决定是否允许在 iframe 中显示该网站的内容。这有助于防止网站遭受点击劫持等攻击,并提高网站的安全性。

在这里插入图片描述

第二中报错描述

Refused to frame '嵌套的网址' because an ancestor violates the following Content Security Policy directive: "frame-ancestors 'self'

在这里插入图片描述

关于 CSP

CSP 是一种安全功能,通过指定允许哪些域将网站内容嵌入框架或 iframe 来帮助防止跨站点脚本 (XSS) 攻击。

白话:把你的地址给第三方,让第三方信任你的网址才能嵌套

这两个方式都能使用nginx代码解决

第一种报错解决

location / { proxy_hide_header X-Frame-Options; proxy_pass [你代理的网址]; }

“proxy_hide_header”指令用于从代理服务器接收的响应中删除“X-Frame-Options”标头。

第二种报错解决

location / { proxy_hide_header Content-Security-Policy; proxy_hide_header X-Frame-Options; proxy_pass https://www.baidu.com; }

并隐藏来自该网站的两个响应头:“Content-Security-Policy” 和 “X-Frame-Options”。



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。