返回顶部
首页 > 资讯 > 精选 >HTTP HSTS协议和 nginx
  • 949
分享到

HTTP HSTS协议和 nginx

2023-06-04 17:06:10 949人浏览 安东尼
摘要

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

Http HSTS协议和 Nginx

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

什么是HSTS

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

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

HTTP HSTS协议和 nginx

HSTS如何工作的

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

1Strict–Transport–Security: max–age=31536000

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

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

1Strict–Transport–Security: max–age=31536000; includeSubDomains

nginx配置HSTS

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

1add_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指令。

123456789101112131415161718server {    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下

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

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

123456789101112131415161718server {    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保护的网站时:

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

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

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

HTTP HSTS协议和 nginx

全球可信CA机构

--结束END--

本文标题: HTTP HSTS协议和 nginx

本文链接: https://lsjlt.com/news/238905.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • HTTP HSTS协议和 nginx
    HTTP HSTS协议和 nginxNetcraft 公司最近公布了他们检测SSL/TLS网站的研究,并指出只有仅仅5%的用户正确执行了HTTP严格传输安全HSTS。本文介绍nginx如何配置HSTS。什么是HSTSHTTPS(SSL和TL...
    99+
    2023-06-04
  • http协议
    http协议 一 http协议概述 HTTP(hypertext transport protocol),即超文本传输协议。这个协议详细规定了浏览器和万维网服务器之间互相通信的规则。 HTTP就是一个通信规则,通信规则规定了客户端发送给服...
    99+
    2023-01-30
    协议 http
  • PHP(13)HTTP协议
    PHP(13)HTTP协议 一、HTTP请求1. 请求行2. 请求头3. 请求体 二、HTTP响应1. 响应行2. 响应头 三、设置HTTP响应四、模拟HTTP请求 一、HTTP请...
    99+
    2023-09-13
    php http 服务器
  • http协议之Range
    http协议中可能会遇到:请求取消或数据传输中断,这时客户端已经收到了部分数据,后面再请求时最好能请求剩余部分(断点续传);或者,对于某个较大的文件,能够支持客户端多线程分片下载... 以上在我们平时应用中已经有很多产品支持了,其中原理就和...
    99+
    2023-09-02
    http 网络 服务器
  • Linux上怎么启用Nginx的HTTP/2 协议支持
    小编今天带大家了解Linux上怎么启用Nginx的HTTP/2 协议支持,文中知识点介绍的非常详细。觉得有帮助的朋友可以跟着小编一起浏览文章的内容,希望能够帮助更多想解决这个问题的朋友找到问题的答案,下面跟着小编一起深入学习“Linux上怎...
    99+
    2023-06-28
  • HTTP协议详解(一)
    目录 1.什么是HTTP协议 2.HTTP的协议格式 使用fiddler抓包工具 理解代理 查看请求内容 3.HTTP请求(Request) 认识URL URL encode 认识method GET方法 POST方法 经典面试题:POST...
    99+
    2023-08-31
    http 网络协议 网络 java 服务器
  • HTTP协议(9)Python requ
    通过Python中的requests模块也可以来发送HTTP请求,接收HTTP响应,从而实现一些更加灵活的操作。requests是第三方库,不过在Kali中已经自带了该模块。Python3和Python2的用法稍微有些差别,这里先以Pyth...
    99+
    2023-01-31
    协议 HTTP requ
  • http和https网络协议是什么
    这篇文章主要介绍http和https网络协议是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!http和https网络协议究竟是什么?在选择代理ip之前,我们需要弄清楚它们的意义吗?是因特网上使用最广泛的一种网络协...
    99+
    2023-06-15
  • 【1】HTTP协议和Socket接口区别
    内容提要:     1.网络七层模型     2.什么是HTTP协议     3.什么是Socket接口   1.网络七层模型   第一层:物理层 为设备之间的信息提供传输提供可靠环境,那么这个环境是什么呢? 如:同轴电缆,插头,接收...
    99+
    2023-01-30
    接口 区别 协议
  • WebSocket协议与HTTP协议的差异与联系
    引言:随着互联网的普及,Web应用的需求不断增加,为了实现实时交互和推送功能,新的通信协议WebSocket应运而生。而传统的HTTP协议也在这个过程中逐渐被WebSocket取代。本文将重点探讨WebSocket协议与HTTP协议的差异与...
    99+
    2023-10-21
    Http websocket 差异与联系
  • HTTP协议实例分析
    这篇文章主要讲解了“HTTP协议实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“HTTP协议实例分析”吧! 在web2.0时代,互联网从传统的C/S...
    99+
    2024-04-02
  • HTTP协议详细介绍
    我们日常生活中经常会使用浏览器访问Web站点这个过程中到底发生了什么吗?为什么我们在浏览器地址栏上面输入要访问的URL后就可以访问到Web页面呢?这几乎是面试过程中的高频问题。 简单...
    99+
    2024-04-02
  • HTTP协议详细解读
    文章目录 1. HTTP概念2. HTTP 特点3. HTTP 协议的工作过程4. 认识URL5. HTTP 请求数据格式6. HTTP 响应数据格式7. 总结📂橙子精品文章学习推荐 1. HTTP概念 HTTP...
    99+
    2023-08-16
    http java 网络
  • 【网络】HTTP协议详解
    😀大家好,我是白晨,一个不是很能熬夜😫,但是也想日更的人✈。如果喜欢这篇文章,点个赞👍,关注一下👀白晨吧!你的支持就是我最大的动力!💪💪...
    99+
    2023-08-23
    网络 http 网络协议 服务器 c++
  • nginx如何配置wss协议
    这篇文章主要讲解了“nginx如何配置wss协议”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“nginx如何配置wss协议”吧!需求:nginx配置websocket协议连接,(背景,在一个...
    99+
    2023-07-05
  • HTTP协议中请求方法的Get和Post
    HTTP协议中请求方法Get和Post的区别是什么?Get:是以实体的方式得到由请求URI所指定资源的信息,如果请求URI只是一个数据产生过程,那么最终要在响应实体中返回的是处理过程的结果所指向的资源,而不是处理过程的描述。 Post:用来...
    99+
    2023-06-03
  • HTTP 协议的演变史:从 HTTP/1.0 到 HTTP/2.0。
    HTTP 协议是互联网上最重要的应用层协议之一,它负责在客户端和服务器之间传输数据。随着互联网的不断发展,HTTP 协议也在不断演变,从最初的 HTTP/0.9 到现在的 HTTP/2.0,不断地改进和完善。本文将为您介绍 HTTP 协议的...
    99+
    2023-08-31
    bash numy http
  • web框架原理,http 协议
    目录 web框架原理 web框架是什么东西 执行代码用浏览器访问一下 输出结果 http 协议 ...
    99+
    2023-01-31
    框架 原理 协议
  • C++中的HTTP协议问题
    目录1、HTTP2、http请求-响应模型3、主要特点4、工作流程5、http请求的组成6、短连接和长连接7、http中的操作8、GET与POST的区别总结1、HTTP Hyper ...
    99+
    2022-12-28
    C++中HTTP协议 HTTP协议 C++ HTTP协议
  • http协议详解(超详细)
    http1. 基础概念篇1.1 介绍  HTTP是Hyper Text Transfer Protocol(超文本传输协议)的缩写。它的发展是万维网协会(World Wide Web Consortium)和Intern...
    99+
    2023-06-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作