你的网站加入 HSTS preload 预加载列表了吗
2024年01月10日 16:56:36 · 本文共 2,074 字阅读时间约 7分钟 · 5,796 次浏览目前在 Google Chrome 浏览器强推 HTTPS 以后,现在几乎大部分网站都已经是 HTTPS 协议访问了,你是否听说过 HSTS(HTTP Strict Transport Security) HTTP严格传输安全?让你的网站更安全,加载更快速。
前提
你的网站必须支持 HTTPS 协议访问,并且所有子域名都支持 HTTPS 协议访问,如果任何一个子域名不支持 HTTPS 协议,那么就不用往下看了,这篇博文内容不适合你的情况。
HSTS
HSTS(HTTP Strict Transport Security) 是HTTP严格传输安全的意思,是由互联网工程任务组发布的互联网安全策略机制。网站可以选择使用 HSTS 策略,来让浏览器强制使用 HTTPS 与网站进行通信,以减少会话劫持风险。
当你的网站使用 HSTS 策略以后,浏览器将放弃 HTTP 明文请求,直接强制用户使用 HTTPS 进行安全加密访问,这样运营商或网络中间者就无法对你的网站进行劫持。
要开启 HSTS 策略,你只需要在 HTTPS 的响应头中增加一个 Strict-Transport-Security 头,有以下三种写法:
- Strict-Transport-Security: max-age=31536000
- Strict-Transport-Security: max-age=31536000; includeSubDomains
- Strict-Transport-Security: max-age=31536000; includeSubDomains; preload
其中 max-age 是 HSTS 策略存活时间,比如设置 31536000 就是告诉浏览器在接下来 31536000 秒之内可以强制用户使用 HTTPS 协议来访问网站;includeSubDomains 的意思是包含子域名,如果你加上了 includeSubDomains 就是告诉浏览器这个域名的子域名也是同样可以强制用户使用 HTTPS 协议来访问网站;preload 的意思是允许预加载,如果你加上 preload 就是告诉浏览器可以被纳入预加载列表中,这也是本篇博文要说的重点。
有关 HSTS 的更多详细信息,请参阅:RFC 6797。
预加载列表
上一段落中我提到了 preload 预加载,并且在博文开头说了可以让网站加载更快,这都得益于 HSTS preload 预加载列表。
我们知道包括 Google Chrome 浏览器在内很多浏览器的内核都是 Chromium 这个开源项目的内核,而这个开源项目就维护了一个列表,这个列表位于 Chromium 代码之中!
可以在chromium的源码中查询到:https://source.chromium.org/chromium/chromium/src/+/main:net/http/transport_security_state_static.json?q=renfei.net&ss=chromium
一旦你的网址进入 HSTS preload 预加载列表,也就是在 Chromium 代码之中增加了你的网站名单,无论用户是否访问过你的网站,浏览器都会强制使用 HTTPS 协议访问你的网站。
这也是为什么说可以加速你的网站访问,因为少去了一步 HTTP 重定向到 HTTPS 这一步,直接就是强制 HTTPS 访问,无需和网站提前有任何交互。
如果你想查询一个域名是否已经在浏览器中内置可以打开 Chrome 的设置页面:chrome://net-internals/#hsts,在 Query HSTS/PKP domain 这里进行查询。
加入 HSTS preload 预加载列表的意义
我为什么要加入 HSTS preload 预加载列表?
首先,我的网站已经完全全部支持 HTTPS 协议访问了,所以可以省去 HTTP 重定向到 HTTPS 这一步,增加访问速度。
其次,是有效防止会话劫持风险,目前无论是运营商还是中间人,都无法劫持 HTTPS 的内容,但他们可以在第一步 HTTP 重定向到 HTTPS 这一步进行劫持,但如果你加入了 HSTS preload 预加载列表,浏览器就不会尝试使用 HTTP 去请求,而是强制使用 HTTPS。
防止 NTP 攻击
目前,HSTS 是一种相当强大的强制 HTTPS 连接的方式。危害 HSTS 的唯一实用方法是基于对网络时间协议 (NTP) 的攻击,该攻击试图通过伪造 NTP 服务器的时间值来操纵系统时间。这使得攻击者可以欺骗浏览器使 HSTS 条目过期并允许不安全的 HTTP 连接。加入 HSTS preload 预加载列表以后将有效防止这种情况。
加入 HSTS preload 预加载列表
- 首先,你的一级域名要能够从 HTTP 重定向到 HTTPS
- 然后,使用 HTTPS 访问一级域名时,增加相应头:Strict-Transport-Security: max-age=31536000; includeSubDomains; preload
- 注意,max-age 必须至少为 31536000秒(1年);includeSubDomains 必须存在;preload 必须存在
- 设置好响应头以后,到:https://hstspreload.org 进行检查,如果没有问题,会看到 Submit 提交表单,提交申请即可
- 等待下周 Chromium 的更新,你的域名将随着源代码进入 HSTS preload 预加载列表
HSTS preload 预加载列表的危险
如果你加入了 HSTS preload 预加载列表,那么今后你域名包括所有子域名,浏览器都将强制 HTTPS 协议访问,所以你必须确保你所有子域名可以使用 HTTPS 协议访问,否则将无法打开你的网站页面!
你也可以退出 HSTS preload 预加载列表,但是由于缓存的原因,完全退出可能需要一年或更久的时间。
版权声明:本文为博主「任霏」原创文章,遵循 CC BY-NC-SA 4.0 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.renfei.net/posts/1626402130325676117
相关推荐
猜你还喜欢这些内容,不妨试试阅读一下- 前后端分离项目接口数据加密的秘钥交换逻辑(RSA、AES)
- OmniGraffle 激活/破解 密钥/密匙/Key/License
- CleanMyMac X 破解版 [TNT] 4.6.0
- OmniPlan 激活/破解 密钥/密匙/Key/License
- 人大金仓 KingbaseES V8 R3 安装包、驱动包和 License 下载地址
- Parallels Desktop For Mac 16.0.1.48911 破解版 [TNT]
- Redis 未授权访问漏洞分析 cleanfda 脚本复现漏洞挖矿
- Parallels Desktop For Mac 15.1.4.47270 破解版 [TNT]
- Sound Control 破解版 2.4.2
- 向谷歌搜索引擎主动推送网页的教程 Google Indexing API 接口实现
- 博客完全迁移上阿里云,我所使用的阿里云架构
- 微软确认Windows 10存在bug 部分电脑升级后被冻结
- 大佬们在说的AQS,到底啥是个AQS(AbstractQueuedSynchronizer)同步队列
- 比特币(BTC)钱包客户端区块链数据同步慢,区块链数据离线下载
- Java中说的CAS(compare and swap)是个啥
- 小心免费主题!那些WordPress主题后门,一招拥有管理员权限
- 强烈谴责[wamae.win]恶意反向代理我站并篡改我站网页
- 讨论下Java中的volatile和JMM(Java Memory Model)Java内存模型
- 新版个人网站 NEILREN4J 上线并开源程序源码
- 我站近期遭受到恶意不友好访问攻击公告