网易首页 > 网易号 > 正文 申请入驻

HTTP HSTS协议和 nginx

0
分享至

Netcraft 公司最近公布了他们检测SSL/TLS网站的研究,并指出只有仅仅5%的用户正确执行了HTTP严格传输安全HSTS。本文介绍nginx如何配置HSTS。

什么是HSTS

HTTPS(SSL和TLS)确保用户和网站通讯过程中安全,使攻击者难于拦截、修改和假冒。当用户手动输入域名或http://链接,该网站的第一个请求是未加密的,使用普通的http。最安全的网站立即发送回一个重定向使用户引向到https连接,然而,中间人攻击者可能会攻击拦截初始的http请求,从而控制用户后续的回话。

自然而然HSTS应运而生为了解决这一潜在的安全问题。即时用户输入域名或http连接,浏览器将严格的升级到https连接。

HSTS如何工作的

HSTS策略是从安全的HTTPS站点发送的HTTP响应头部发布的。

Strict-Transport-Security: max-age=31536000

当浏览器从HTTPS站点看到这个头部,就知道该域名只能通过HTTPS(SSL 或者 TLS)访问了。并将此信息缓存到31536000,也就是1年。

可选的参数includeSubDomains告诉浏览器该策略适用于当前域下的所有子域。

Strict-Transport-Security: max-age=31536000; includeSubDomains

nginx配置HSTS

在nginx配置文件上设置HSTS响应头部。

add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;

always 参数确保所有的响应设置该头部,包括内部产生的错误响应。nginx版本早于1.7.5不支持该always参数和内部产生的错误响应不设置该头部信息。

add_header指令继承规则:

nginx配置块继承add_header指令所在的封装块,因此只需将add_header指令放在顶级的server块。此外还有个重要的例外,如果一个块包含了add_header指令本身,它不会从封装块继承该头部,你需要重新定义所有的add_header指令。

server {
listen 443 ssl;
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;
# This 'location' block inherits the STS header
location / {
root /usr/share/nginx/html;
}
# Because this 'location' block contains another 'add_header' directive,
# we must redeclare the STS header
location /servlet {
add_header X-Served-By "My Servlet Handler";
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;
proxy_pass http://localhost:8080;
}
}

测试HTTP严格传输安全:

一旦用户提出HSTS策略,它的缓存信息期由max-age指定。在此期间,浏览器将会拒绝通过未加密的HTTP访问web服务,并拒绝给予例外证书错误(如果该网站以前提交了一个有效可信的证书)。如果指定了一个includeSubDomanis参数,这些限制也同样适用于当前域下的所有子域。

当你测试HSTS时,max-age时间设置短点。

是否每个HTTPS响应需要有一个STS头部:

我们的目标是当用户开始HTTPS回话时,尽可能快的呈现HSTS策略。如果他们在回话期间接收到HSTS策略,他们仍然容易受到HTTP劫持攻击的。浏览器只需查看一次STS头部,因此它不是严格必要将它添加到每个位置块和每个响应。然而,只在主页或者登陆页面添加它可能是不够的,如果你只添加到缓存的响应,客户端可能无法看到它。确保尽可能多的合理的覆盖到你的URL,特别注意动态的内容。

HTTP和HTTPS并行

有时网站需要同时运行在HTTP和HTTPS下

server {
listen 80;
listen 443 ssl;
...
}

有时,需要将http请求重定向到https

server {
listen 80 default_server;
listen [::]:80 default_server;
server_name _;
# Discourage deep links by using a permanent redirect to home page of HTTPS site
return 301 https://$host;
# Alternatively, redirect all HTTP links to the matching HTTPS page
# return 301 https://$host$request_uri;
}
server {
listen 443 ssl;
server_name www.ttlsa.com;
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;
}

加强HSTS

保护客户端从HTTP拦截,从它看到STS头部到声明的max-age的期间内。然而,HSTS并不是HTTP回话劫持的完美解决方案。用户仍然容易受到攻击,如果他们通过HTTP访问HSTS保护的网站时:

  1. 以前从未访问过该网站
  2. 最近重新安装了其操作系统
  3. 最近重新安装了其浏览器
  4. 切换到新的浏览器
  5. 切换到一个新的设备如移动电话
  6. 删除浏览器的缓存
  7. 最近没访问过该站并且max-age过期了

为了解决这个问题,google坚持维护了一个“HSTS preload list”的站点域名和子域名,并通过https://hstspreload.appspot.com/提交其域名。该域名列表被分发和硬编码到主流的web浏览器。客户端访问此列表中的域名将主动的使用HTTPS,并拒绝使用HTTP访问该站点。

一旦设置了STS头部或者提交了你的域名到HSTS预加载列表,这是不可能将其删除的。这是一个单向的决定使你的域名通过HTTPS可用的。

  • 原文来自:http://www.ttlsa.com/nginx/http-hsts-nginx/
  • 本文地址:https://www.linuxprobe.com/http-hsts-nginx.html编辑:杨鹏飞,审核员:逄增宝

本文原创地址:https://www.linuxprobe.com/http-hsts-nginx.html编辑:public,审核员:暂无

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
史诗级封杀!2000万网红“听风的蚕”彻底凉了

史诗级封杀!2000万网红“听风的蚕”彻底凉了

互联网品牌官
2026-02-12 01:17:23
1170万加盟中超冠军!20岁后卫西协丙无球可踢,回国1年直接起飞

1170万加盟中超冠军!20岁后卫西协丙无球可踢,回国1年直接起飞

球叮足球
2026-02-14 09:47:20
晚饭七分饱被推翻了?医生调查:过了56岁,吃饭尽量要做到这5点

晚饭七分饱被推翻了?医生调查:过了56岁,吃饭尽量要做到这5点

蜉蝣说
2026-02-03 15:00:19
郑丽文终于表态了:提出统一3大主张!大陆破例批准,局势或变?

郑丽文终于表态了:提出统一3大主张!大陆破例批准,局势或变?

风眼军情
2026-02-14 20:34:14
42岁刘翔近况曝光,长期在国外旅游,靠终身合同吸金,远离喷子!

42岁刘翔近况曝光,长期在国外旅游,靠终身合同吸金,远离喷子!

姩姩有娱
2025-11-10 17:49:18
美团的死穴决定了它打不起这场补贴大战

美团的死穴决定了它打不起这场补贴大战

新浪财经
2026-02-14 15:33:26
联手哈登,有望重返骑士!老将组合注定无冠,最大受害者出现了

联手哈登,有望重返骑士!老将组合注定无冠,最大受害者出现了

体育大朋说
2026-02-14 20:58:28
你知道什么是降维打击吗?网友:符合高中学历的认知

你知道什么是降维打击吗?网友:符合高中学历的认知

带你感受人间冷暖
2026-02-13 21:51:11
帕金斯:文班亚马才是联盟下个门面,亚历山大约基奇都做不到这点

帕金斯:文班亚马才是联盟下个门面,亚历山大约基奇都做不到这点

大眼瞄世界
2026-02-14 21:35:51
这才是铁哥们!还清中国81亿欠债,赠百亿大礼,西方各国都眼红

这才是铁哥们!还清中国81亿欠债,赠百亿大礼,西方各国都眼红

霁寒飘雪
2025-12-30 11:54:50
突发!上海嘉闵线渗漏后再塌陷,城市地下基建安全警钟必须长鸣

突发!上海嘉闵线渗漏后再塌陷,城市地下基建安全警钟必须长鸣

坠入二次元的海洋
2026-02-14 09:19:30
春节租车“爆”了

春节租车“爆”了

中国新闻周刊
2026-02-13 22:36:10
中美谈了60分钟,鲁比奥赔笑脸,美方松开王毅的手,对华作出承诺

中美谈了60分钟,鲁比奥赔笑脸,美方松开王毅的手,对华作出承诺

影孖看世界
2026-02-14 22:49:48
就在刚刚,30家公司出现重大利好消息,有没有与你相关的个股?

就在刚刚,30家公司出现重大利好消息,有没有与你相关的个股?

股市皆大事
2026-02-14 13:53:25
河南小伙在非洲16年,当地一夫多妻制,男人只用玩,女人挣钱养家

河南小伙在非洲16年,当地一夫多妻制,男人只用玩,女人挣钱养家

大鱼简科
2026-02-07 16:50:52
戴维森:能继续留在中国效力非常棒,这里的生活质量很高

戴维森:能继续留在中国效力非常棒,这里的生活质量很高

懂球帝
2026-02-14 17:02:04
王菲或将六登央视春晚

王菲或将六登央视春晚

大象新闻
2026-02-14 18:43:04
苹果也“不讲武德”,Mac主机仅2386元,给Windows重力一击

苹果也“不讲武德”,Mac主机仅2386元,给Windows重力一击

时尚的弄潮
2026-02-12 11:16:46
燃油车再霸榜!1月MPV销量榜揭晓,赛那又夺冠,腾势D9跌出前十

燃油车再霸榜!1月MPV销量榜揭晓,赛那又夺冠,腾势D9跌出前十

购车前线
2026-02-14 02:40:05
票房会破30亿?看完《镖人》预告,我断言:武侠片的荣光又回来了

票房会破30亿?看完《镖人》预告,我断言:武侠片的荣光又回来了

皮皮电影
2026-02-14 14:01:09
2026-02-14 23:47:00
孙有匪 incentive-icons
孙有匪
科技
1595文章数 2008关注度
往期回顾 全部

科技要闻

字节跳动官宣豆包大模型今日进入2.0阶段

头条要闻

福州街头发现一流浪老人身份成谜 程序员精准破解方言

头条要闻

福州街头发现一流浪老人身份成谜 程序员精准破解方言

体育要闻

最戏剧性的花滑男单,冠军为什么是他?

娱乐要闻

春晚第五次联排路透 明星积极饭撒互动

财经要闻

谁在掌控你的胃?起底百亿"飘香剂"江湖

汽车要闻

星光730新春促销开启 80天销量破2.6万台

态度原创

时尚
房产
健康
家居
军事航空

推广中奖名单-更新至2026年2月3日推广

房产要闻

三亚新机场,又传出新消息!

转头就晕的耳石症,能开车上班吗?

家居要闻

中古雅韵 乐韵伴日常

军事要闻

钓鱼岛、黄岩岛、仁爱礁已充满中国年味

无障碍浏览 进入关怀版