【学习笔记】SSL/TLS安全机制之HSTS

1、What:HSTS全称HTTP Strict Transport Security,HTTP严格传输安全。

2、Why:因为HTTP 在重定向到 HTTPS 之前存在漏洞

  • 用户在浏览时很少明确输入 https://
    • 有时,用户正好通过http来访问网站,网站服务器知道这应该是安全访问,然后进行http 301重定向(redirect),以此来告诉Client再次请求并且这次用https
      • 初始的请求可能成为(中间人的)攻击媒介

3、What HSTS Trying to Solve

  • SSL Stripping Attack (SSL剥离攻击)- 中间人代理HTTP到HTTPS连接
    • DEF CON 17 - Moxie Marlinspike - More Tricks for Defeating SSL(一个演讲)

4、How it happens

  • HSTS指示浏览器"site.com"被访问时必须总是以HTTPS的方式
    • 用户通过HTTPS浏览网站
    • 然后Web Server会提供该网站的内容,还有HSTS指令:
      • max-age - 自动通过 HTTPS 请求站点的持续时间(秒)
      • includeSubDomains - (重定向)自动应用到所有子域名,例如www.site.com、mail.site.com等
    • 示例,当我们在浏览器地址栏输入http://site.com,会自动重定向到https://site.com
      • 我们打开Chrome - 更多工具 - 开发者工具 - Network - 点击Name的第一个 - Headers,得到如上图所示内容。我输入的请求是http,我得到的响应是Internal Redirect,告诉我应该用https来访问该网站。由上图可看到,重定向的理由是HSTS。307 Internal Redirect表明我们的请求实际上并未成功,也表明中间人无法进行有效攻击,本例中Chrome自动将http重定向到https。
    • 不幸的是,我们首次访问网站时仍然容易受到剥离攻击(SSL Stripping),HSTS的制造者也考虑到这一点了
    • HSTS Preload
    • 综上,网站提供了3种 HSTS 指令,分别是max-ageincludeSubDomainspreload
  • 好处:HSTS 还会禁用点击 SSL/TLS 警告的功能
    • 例如,用户通过HTTPS访问(在HSTS列表上的)网站,然后收到了证书错误,浏览器会禁用点击SSL警告的功能(也就没法继续访问了)
  • 此外,3种指令通常出现在同一行,某种程度上他们以同种方式工作

5、根据该网站- Qualys SSL Labs - SSL Pulse 2024年5月3日调查的网站总数为134495个,我们可以看到目前有47863个网站支持HSTS,占比35.6%

参考文献

1、网站:Practical Networking.net:Practical TLS

相关推荐
DeBuggggggg9 小时前
linux 安装Python3.9 且支持SSL
linux·运维·ssl
勇往直前plus1 天前
Docker 拉取镜像:SSL 拦截与国内镜像源失效问题解决
docker·容器·https·ssl
chen36732 天前
[Comake][D1][AI_AO][bf_ssl_demo]
网络·网络协议·ssl
微小冷4 天前
WireShark抓包http,解密https
http·https·edge·wireshark·ssl·解密
普普通通的南瓜4 天前
《国家安全法》下的 SSL 证书定位:网络数据加密的 “法定基石”
网络·php·ssl
问道飞鱼4 天前
【知识科普】完整的 SSL 证书文件体系
网络协议·https·证书·ssl
2501_938963964 天前
服务器数据库安全:MySQL 开启 SSL 连接,禁止远程 root 登录并限制 IP 访问
服务器·mysql·ssl
普普通通的南瓜5 天前
金融交易防护:国密 SSL 证书在网银与移动支付中的核心作用
网络·网络协议·安全·arcgis·gitlab·ssl·源代码管理
运维行者_6 天前
运维实战:SSL 证书故障避坑指南(精简版)
运维·网络协议·ssl
TG:@yunlaoda360 云老大7 天前
腾讯云国际站SSL:腾讯云SSL证书的SSL握手过程,如何实现高效的身份验证?
云计算·腾讯云·ssl