AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1060208
Accepted
ImBoredAllTheTime
ImBoredAllTheTime
Asked: 2021-04-13 21:39:14 +0800 CST2021-04-13 21:39:14 +0800 CST 2021-04-13 21:39:14 +0800 CST

Host: 是否需要 SSL 标头?

  • 772

即使请求不是 HTTP/1.1,主机是否也需要 SSL 标头?

因此,如果客户端通过 SSL 连接,并发送以下请求:

GET / HTTP/1.0
  1. Web 服务器是否应该由于缺少 Host: 标头而引发错误请求?
  2. Web 服务器是否应该使用 HTTP/1.0 200 OK 响应来响应?( index.html 文件始终存在,因此对/
    的请求永远不会导致 403/404)

更新:

如果我在 中禁用 SNI openssl s_client,则 apache 将在没有 Host: 标头的情况下工作。

为什么在 SNI 开启时需要 Host: 标头?

http ssl host-headers
  • 2 2 个回答
  • 2972 Views

2 个回答

  • Voted
  1. Best Answer
    Steffen Ullrich
    2021-04-14T00:31:06+08:002021-04-14T00:31:06+08:00

    根据标准,HTTP/1.0 请求不需要 Host,但在实践中通常仍需要此标头来决定要提供哪些内容的多域设置。但是,如果此标头不存在并且仍然清楚要提供哪些内容,则可以在不需要标头的情况下提供此内容。请注意,这与 TLS 和使用 SNI 无关。

    • 18
  2. kbolino
    2021-04-14T11:47:38+08:002021-04-14T11:47:38+08:00

    要回答更新中添加的部分问题,

    为什么在 SNI 开启时需要 Host: 标头?

    “需要”是一个强词,但它有助于理解 SNI 和 HTTP 标头在两个不同的层上运行,因此服务于两个不同的目的。

    SNI主要用于确定向客户端提供哪个证书。在具有多个虚拟主机的设置中,在解密有效负载之前,服务器必须向客户端提供证书。由于证书包含站点的名称,传统上是证书主题的通用名称,但最近在 X.509 扩展主题替代名称中,提供错误的证书会导致客户端在发送 HTTP 请求之前拒绝连接到服务器。

    而Host标头主要用于确定要服务的资源。在表现良好的客户端中,这与 SNI 中的名称是多余的,但 HTTP/1.1 与SSL 3.0几乎同时开发,因此甚至早于 TLS-SNI 扩展存在。事实上,正是 HTTP/1.1 和 SSL/TLS 的结合才发现了对 SNI 的需求。

    值得注意的是,HTTP/2不需要标Host头,但具有:authority伪标头形式的功能等效项。尽管在大多数情况下,该标头中的信息对于 TLS-SNI 仍然是冗余的,但它简化了实现以始终包含它。

    始终包含Host(or :authority) 标头也留下了准系统 SSL 终止的可能性(尽管实际上很少支持没有 TLS 的 HTTP/2)。但是,不验证主机/权限是否与 TLS-SNI 中的名称匹配可能会在某些设置中打开安全漏洞。

    • 6

相关问题

  • 设置 http 代理以使用 Web 界面?

  • 无法连接到 Ubuntu Desktop 中的端口 80 或 VMWare Workstation 6.52 中的 Server 9.04

  • IIS 7.5 (Windows 7) - HTTP 错误 401.3 - 未经授权

  • 为什么有些网站的网址中没有“www”就无法显示?[关闭]

  • Tomcat 6 HTTP 日志滚动和清除

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve