it编程 > 网页制作 > 网页播放器

使用noopener和noreferrer让HTML中的外部链接更安全

15人参与 2025-12-08 网页播放器

前言

刚学前端那会儿,我处理外链的方式简单粗暴:

<a href="https://example.com">随便一个外链</a>

点一下,当前标签直接跳走。 用户刚打开好不容易进来的页面,下一秒——嗖地没了。

后来我发现 target="_blank" 这个“神器”:

<a href="https://example.com" target="_blank">在新标签打开的外链</a>

从此以后,外链都乖乖在新标签里打开:

体验一下子顺眼了很多,我自己也用得很爽。 直到有一天,我才知道:

只加 target="_blank",你其实给自己埋了一个安全坑。

问题不在“新标签”,而在它背后悄悄多出的那根“线”

当你用 target="_blank" 打开一个新标签时, 浏览器会在两个页面之间,悄悄建立一条 javascript 通道

具体来说:

新开的页面,可以通过一个叫 window.opener 的对象, 直接“反向操作”你的原页面。

就像这样简单粗暴的一行:

window.opener.location = 'https://a-new-page.com';

意思就是:

“把原来的那一页,重定向到我指定的这个新地址。”

这种操作,有个专业(但听起来就很阴间)的名字:tabnabbing(标签劫持)

你以为你只是好心把外链丢到新标签页, 结果人家顺着这条“绳子”,直接把你的原页面拖走了。

更可怕的是——用户根本意识不到发生了什么。

全程没警觉,你的平台就这样被“借壳上演了一场骗局”。

哪些场景尤其危险?

这种“标签劫持”风险,对下面这些场景尤其致命:

只要你的用户:

那一旦被人利用 window.opener 做文章,你和用户就一起掉坑里了。

一行就能补上的安全大洞:rel="noopener noreferrer"

好消息是,修这个问题,真的只要 加一小段属性

<a href="https://example.com" target="_blank" rel="noopener noreferrer">更安全的外链</a>

就这一行:

rel="noopener noreferrer"

后面这两个值,分别干这些事:

noopener:直接剪断那根“控制原页面”的线

rel="noopener" 的作用是:

告诉浏览器: “新开的那一页,不允许通过 window.opener 访问/控制我。”

也就是说:

tabnabbing 这条攻击链,直接被斩断。

noreferrer:顺带把“我是谁”也隐藏掉

rel="noreferrer" 做的事情是:

在跳转时,不再把“从哪个页面来的”这个信息, 通过 http referer 头部传给目标站点。

简单说:

两个属性一起用,就是现在业界推荐的“标配”:

rel="noopener noreferrer"

它们一起做到了:

你付出的成本? 不过就是在 <a> 标签里,多敲了 20 来个字符而已。

“浏览器不是已经帮我自动加 noopener 了吗?”

确实,部分现代浏览器 在某些场景里, 会自动为 target="_blank" 的外链加上 noopener

但问题有两个:

  1. 并不是所有浏览器都这么做

  2. 你也不能保证将来改动、第三方组件、特殊环境里不会漏掉

作为一个开发者, 在这种“成本极低、收益极大”的地方, 与其赌浏览器,不如自己写死。

亲手多写 1 行, 好过哪天追着用户说:“这个问题是浏览器的问题,不是我。”

什么时候该用?什么时候不必用?

这对组合,也不是“逢 <a> 必加”。

可以简单记住一条:

给“外链”加上它

这些地方,一律建议:

<a href="https://third-party.com" target="_blank" rel="noopener noreferrer">第三方页面</a>

内部导航,正常情况下不用加

如果你的链接是:

那就不必强行加 noopener。 在同一个受控环境下,相互通信本身就是设计的一部分。

但有一点可以坚守:

只要是 “点了就跳出我控制范围” 的链接, 我都会习惯性补上这两个属性。

顺手一个小优化:用 css 标记所有“会开新标签的外链”

为了给用户一点“视觉提示”, 我还习惯顺带加一点点 css:

a[target="_blank"] {
  cursor: pointer;
}

a[target="_blank"]::after {
  content: "↗";
  font-size: 0.8em;
  margin-left: 0.25em;
}

这样用户一眼就能看出来:

ux 更清晰,安全感也更足一点。

最后一句:真正“专业”的前端,很多时候就藏在这种小细节里

rel="noopener noreferrer" 看起来只是一个不起眼的小属性。

可它解决的是一个:

“安安静静存在了很多年,但一旦被利用就很致命”的问题。

你多写这一行:

成本几乎为零,收益却相当可观。

所以,下次你再写:

<a href="https://example.com" target="_blank">外链</a>

不妨养成一个小习惯,顺手补上这一段:

rel="noopener noreferrer"

就这一行, 让外链安全了一大截。

链接类型处理表格

链接类型targetrel属性说明
内部链接不设置或_self(无需)站内导航
内部资源_blanknoopenerpdf、下载文件等
可信外部_blanknoopener noreferrer合作伙伴、参考资料
用户内容_blankugc nofollow noopener noreferrer评论、论坛帖子
广告链接_blanksponsored nofollow noopener noreferrer付费广告、推广
社交媒体_blanknoopener noreferrer分享按钮
登录/注册_blanknoopener noreferreroauth认证等

总结

到此这篇关于使用noopener和noreferrer让html中的外部链接更安全的文章就介绍到这了,更多相关noopener和noreferrer让html外链更安全内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

您想发表意见!!点此发布评论

推荐阅读

证书安装IIS

12-06

若依框架(超详细教程)

12-10

如何使用C#实现将Excel文件转换为HTML格式

10-31

C#利用.NET实现Word文档到HTML的高效转换

10-31

C#使用Spire.Doc将HTML转换为文本的代码实现

10-12

C#使用Spire.Doc for .NET将HTML转换为图像

10-10

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论