HTML中rel属性的取值及在链接安全中的作用rel属性用于定义当前文档与被链接文档之间的关系,常用于、和标签中。它不仅有助于搜索引擎优化(SEO),还在提升网站安全性方面发挥重要作用。以下是一些常见的rel属性取值及其在链接安全中的作用:1. rel="nofollow"作用:告诉搜索引擎不要追踪该链接,也不传递权重。安全作用:防止垃圾链接或恶意网站通过你的页面获得
时间:2026-05-14 16:54:46 466浏览 收藏
HTML中的rel属性虽常被用于SEO优化,但真正关乎浏览器安全的仅有noopener和noreferrer两个取值,且二者必须与target="_blank"配合使用才能生效:noopener防止新页面通过window.opener劫持原页面,noreferrer进一步阻断Referer头泄露来源信息;其他如nofollow、external等值纯属语义标记,对安全毫无实质作用——理解这一关键限制,尤其是Safari 15.4前的兼容性陷阱,才是防范钓鱼、DOM劫持和信息泄露的核心所在。

rel 属性没有“所有取值”的官方穷举列表,HTML 标准只定义了一组**规范值(valid values)**,其余是扩展或历史遗留值;在链接安全中,真正起作用的只有 noopener 和 noreferrer,且必须配合 target="_blank" 才有意义——其他值如 nofollow 或 external 对安全无实质影响。
哪些 rel 值会影响浏览器安全行为
只有两个值会直接改变新页面的执行上下文和请求头:
noopener:阻止新打开的页面通过window.opener访问原页面的window对象,避免钓鱼或 DOM 劫持noreferrer:不仅包含noopener效果,还会让浏览器不发送Referer请求头,防止目标站获知来源 URL- 二者可共存:
rel="noopener noreferrer"是当前最稳妥的写法 nofollow、external、ugc等纯属 SEO 语义,浏览器完全忽略其安全含义
为什么只对 a 标签 + target="_blank" 有效
noopener 和 noreferrer 的作用机制依赖于“新浏览上下文”的创建,而 HTML 中仅当 a 标签带 target="_blank"(或非 _self 的 target)时,浏览器才会新建一个独立的 browsing context。其他场景下设置它们无效:
—— 语法合法但被浏览器静默忽略不带target—— 即使写了rel="noopener"也无实际效果target="_self"或未声明target—— 页面仍在当前上下文中跳转,不存在 opener 风险
常见错误写法与后果
这些写法看似“更安全”,实则要么多余,要么掩盖真实风险:
- 只写
rel="noreferrer":现代 Chrome/Firefox 已自动补noopener,但 Safari 15.4 之前不兼容,仍有 opener 漏洞 - 写成
rel="nofollow noopener":nofollow对安全零贡献,还可能误导后续维护者以为“已加固” - 给内部跳转加
noopener(如):没必要,且增加内存开销(新上下文无法复用) - 误以为
rel="external"能防 XSS:它只是语义标记,浏览器不据此隔离上下文
真正关键的不是“用了多少 rel 值”,而是是否理解 noopener 的触发条件和浏览器兼容边界——Safari 15.4 是分水岭,此前版本必须显式同时写 noopener noreferrer 才可靠。
终于介绍完啦!小伙伴们,这篇关于《HTML中rel属性的取值及在链接安全中的作用rel属性用于定义当前文档与被链接文档之间的关系,常用于、和标签中。它不仅有助于搜索引擎优化(SEO),还在提升网站安全性方面发挥重要作用。以下是一些常见的rel属性取值及其在链接安全中的作用:1. rel="nofollow"作用:告诉搜索引擎不要追踪该链接,也不传递权重。安全作用:防止垃圾链接或恶意网站通过你的页面获得SEO优势,降低被黑或钓鱼的风险。使用场景:评论区、用户生成内容(UGC)、广告链接等。2. rel="noopener"作用:防止新打开的页面通过window.opener访问原页面的window对象。安全作用:防止恶意网站通过target="_blank"跳转后操控原页面,保护用户免受钓鱼攻击或恶意脚本注入。使用场景:所有使用target="_blank"的外部链接。注意:现代浏览器已默认对target="_blank"添加rel="noopener",但显式声明更安全。3. rel="noreferrer"作用:阻止新页面获取原始页面的Referer信息。**安全作用》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
434 收藏
-
135 收藏
-
448 收藏
-
265 收藏
-
501 收藏
-
479 收藏
-
154 收藏
-
270 收藏
-
261 收藏
-
140 收藏
-
434 收藏
-
424 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习