聊聊 rel=noopener
同步自我的博客
最近梳理团队 eslint 时,在 airbnb 的配置中发现了这么一项
'react/jsx-no-target-blank': 2
官方文档的介绍大概是这样的
如果你需要用 a 标签打开一个标签页时,你会使用 target='_blank' 这个属性,此时你需要添加 rel='noreferrer noopener'
这就让人很迷惑了,这俩属性是干什么的呢,google 一下方才知道,它是为了解决安全问题。
当你使用 target='_blank'
打开一个新的标签页时,新页面的 window
对象上有一个属性 opener
,它指向的是前一个页面的 window
对象,因此,后一个页面就获得了前一个页面的控制权,so 可怕!!
比如的 a 标签是这样 <a href='/index'>打开连接</a>
,打开后在控制台输入 window.opener.alert(1)
看看?
甚至在跨域的情况下他也可以生效,比如打开 <a href='https://github.com/ZhangFe/Blog'>链接<a/>
后,你可以使用 window.opener.location.replace
更改前一个页面的 url。
那么,为了避免这种情况,就需要咱们的主角登场了!
比如你的链接现在变成了这样 <a href='/index' rel=noopener>链接<a/>
,再打开后你会发现 window.opener
已经被置为了 null,如果是一些旧的浏览器,可以使用 rel=noreferrer
,它不仅禁用了 window.opener
,后一个页面也无法获取到 referrer
,再不行,可以利用 js 来打开新的页面,之后将 opener
置为 null
来完成这个功能
var otherWindow = window.open();
otherWindow.opener = null;
otherWindow.location = url;
参考文档
https://html.spec.whatwg.org/...
https://mathiasbynens.github....
【推荐】博客园的心动:当一群程序员决定开源共建一个真诚相亲平台
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】Flutter适配HarmonyOS 5知识地图,实战解析+高频避坑指南
【推荐】开源 Linux 服务器运维管理面板 1Panel V2 版本正式发布
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 为什么说方法的参数最好不要超过4个?
· C#.Net 筑基-优雅 LINQ 的查询艺术
· 一个自认为理想主义者的程序员,写了5年公众号、博客的初衷
· 大数据高并发核心场景实战,数据持久化之冷热分离
· 运维排查 | SaltStack 远程命令执行中文乱码问题
· 博客园众包平台:诚征3D影像景深延拓实时处理方案(预算8-15万)
· 发布一个小功能,通过 markdown 图片语法嵌入B站视频
· 《HelloGitHub》第 111 期
· 谷歌新AI工具杀疯了?免费,但有点坑!Gemini CLI 抢先实测
· Spring AI Alibaba 1.0 正式发布!核心特性速览+老项目升级指南