启用HSTS可以保证自己的网站更稳定的被访问,不被运营商各种干扰,劫持,访问时候加入各种广告。启用HSTS后自然想要加入HSTSPreloadList了,这是各大浏览器都遵循的一个强制使用Https访问的网站列表,只要加入到这个列表中,所有的通过浏览器访问请求都会强制走Https,这在很大程度上可以杜绝“第一次”访问的劫持,最大限度地提高Https访问的安全性。
需要注意的是加入HSTSPreloadList需要以根域名的形式加入,如果你启用了www.daniao.org这样的二级域名形式访问,你需要先停止301跳转,即要保证daniao.org这样的根域名是用Https可以访问到的。
HSTS是在服务器强化Https安全,如果你的网站还没有启用Https,可以试试免费的SSL证书Let’sEncrypt。服务器启用SSL证书其实也是一种资源开消,我们需要最大限度地减少这种资源消耗提升https访问速度。启用HSTS便是一种很好的选择。
也普及下HSTS基本知识:HSTS是国际互联网工程组织IETE正在推行一种新的Web安全协议HTTPStrictTransportSecurity(HSTS)。采用HSTS协议的网站将保证浏览器始终连接到该网站的HTTPS加密版本,不需要用户手动在URL地址栏中输入加密地址。
编辑你的apache配置文件(如/etc/apache2/sites-enabled/website.conf和/etc/apache2/httpd.conf),并加以下行到你的HTTPSVirtualHost:
#Apache需加载mod_header库,一般位于httpd.conf文件,搜索mod_headers并取消注释。(已加载可跳过)
LoadModuleheaders_modulemodules/mod_headers.so#然后对应站点VirtualHost里面插入HSTS响应头信息
HeaderalwayssetStrict-Transport-Security"max-age=63072000;includeSubdomains;preload"
保存Apache配置文件,然后重启。现在你的web站点在每次访问时都会发送该请求头,失效时间是两年(秒数),这个失效时间每次都会设置为两年后。
Nginx服务器中的配置最为简单,只需要编辑Nginx配置文件(如:/usr/local/nginx/conf/nginx.conf)将下面行添加到你的HTTPS配置的server块中即可:
add_headerStrict-Transport-Security"max-age=63072000;includeSubdomains;preload";
如果你发现直接添加在server块中无效的情况,你可以试试直接插入到location~*php内:
location~[^/]\.php(/|$){
add_headerStrict-Transport-Security"max-age=63072000;includeSubdomains;preload";
配置保存后重启Nginx服务。
将下述配置增加到你的Lighttpd配置文件(例如:/etc/lighttpd/lighttpd.conf):
server.modules+=("mod_setenv")
$HTTP["scheme"]=="https"{
setenv.add-response-header=("Strict-Transport-Security"=>"max-age=63072000;includeSubdomains;preload")

header("Strict-Transport-Security:max-age=63072000;includeSubdomains;preload");
开启了HSTS后,你部署SSL/TLS的服务检测得分就可能是A+以上了。ssllabs官网以及演示如下:
HSTSpreloadlist是Chrome浏览器中的HSTS预载入列表,在该列表中的网站,使用Chrome浏览器访问时,会自动转换成HTTPS。Firefox、Safari、Edge浏览器也在采用这个列表。
直接打开Chrome查看网络,就可以看到头部已经包含了HSTS信息了。
将daniao.org以及任意二级域名都要做好Http跳转到Https,启用了HSTS后请求地址为header头中的?会显示307,即要求浏览器继续向Location的地址POST内容。
进入hstspreload官网,输入你的域名,然后检测结果会告诉是否符合加入HSTSPreloadList,没有问题的话勾选确定。
HSTSPreloadList审核的时间有长有短,一旦提交后你就只能等待。
3.1?是否成功加入HSTSPreloadList
直接到下列网址搜索是否有你的域名即可:
当然,加入到了HSTSPreloadList后,你可能还需要等待1-2月,待新版本的Chrome和Chromium、Firefox、IE等发布后,你的域名算是正式被各大浏览器承认并强制使用Https访问了,你可以在Chrome浏览器的地址框中输入“chrome://net-internals/#hsts”查看。
3.2?如何撤销HSTSPreloadList
官方也提供了一个申请删除HSTS?PreloadList,不过需要注意的是撤销HSTSPreloadList和加入HSTSPreloadList一样,花费的时间可能需要几个月以上,所以申请HSTS?PreloadList前一定要谨慎。
由于HSTSPreloadList是一个内置于各大浏览器的Https网站列表,所以能否加入成功除了审核通过外,还得看浏览器版本的更新。一旦加入HSTSPreloadList了想要退出就比较麻烦了,所以加入前一定要考虑好。也就是说开启HSTS后服务器上面的同一个根域名的所有子域名都要上Https,所以有的时候我们需要将子域名用来本地开发,每次都要配置HTTPS还是很麻烦的!而且同一个IP上网站域名都要上Https,如果你不部署也会给你强制跳转到https,导致无法打开,这真的是很麻烦。
那么哪些网站适合加入HSTSPreloadList?个人博客或者网站可以来玩一玩,对于安全性要求比较高的电商网站,会员管理后台等完全可以使用HSTSPreloadList,对于一些有Http需要的还是不加入得好。
虽然说https防劫持的效果很好,有的时候想要防数据劫持或广告插入不仅要看https,还要看浏览器。比如UC拉到最底下的时候会经常出现不相干的广告。所以说就算你加入了https也不是万能的,有些流氓浏览器真的没办法。广告劫持通常与DNS过程无关,即使HSTS也无法规避由DNS劫持带来的网站打开错误,这些大家也要了解一下!
本文地址:https://www.idcbaba.com/mianfei/875.html
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 1919100645@qq.com 举报,一经查实,本站将立刻删除。



