如何避免网页被人嵌套在 iframe 里?

黄舟
发布: 2017-07-24 09:19:41
原创
2695 人浏览过

如题,我的网站内容被别人用 iframe 嵌套在自己的网站里了,有没有办法屏蔽不让他嵌套呢?

还有个比较好的办法:

在响应头里加一个X-Frame-Options

取值有三种,大部分浏览器都支持:

DENY:浏览器拒绝当前页面加载任何Frame页面

SAMEORIGIN:frame页面的地址只能为同源域名下的页面

ALLOW-FROM origin:origin为允许frame加载的页面地址

这样被不同源的页面以iframe包含时就不会显示了

写脚本

if (window != window.top) 
{    
window.top.location.replace(window.location)    
// 这是直接代替外窗,你也可以干别的
}
登录后复制
if (window != window.top) 
{
window.top.location.replace(window.location)
//加弹窗代码 干死他们 还赚钱
}
登录后复制

新浪微博是这么做的

if (top != self) 
{    
top.location = self.location;
}
登录后复制

基本可以抵挡大多数iframe嵌套了。

还有看一下人家是怎么利用iframe嵌套实施攻击的,就知道怎么防御了

目前最好的js的防御方案为:

if (self == top) {
    var theBody = document.getElementsByTagName('body')[0];
    theBody.style.display = "block";
} else {
    top.location = self.location;
}
登录后复制

添加过滤脚本。原理是当检测到当前的url链接不是自己的时候,让src指向空白地址。具体代码请google。

以上是 如何避免网页被人嵌套在 iframe 里?的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板