- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在阅读 spec并尝试准确了解 421 何时可能返回。给出了一个例子,但我不太明白。
背景
该规范建立了两个允许连接重用的条件:
For TCP connections without TLS, this depends on the host having resolved to the same IP address.
和
For https resources, connection reuse additionally depends on having a certificate that is valid for the host in the URI.
如果连接中使用的证书有多个subjectAltName
或 subjectAltName
中的任何一个是通配符,则该连接可以重复用于主机名位于 subjectAltName
列表中的任何请求。 s 或 匹配任何通配符。
规范中的具体示例
In some deployments, reusing a connection for multiple origins can result in requests being directed to the wrong origin server. For example, TLS termination might be performed by a middlebox that uses the TLS Server Name Indication (SNI) [TLS-EXT] extension to select an origin server. This means that it is possible for clients to send confidential information to servers that might not be the intended target for the request, even though the server is otherwise authoritative.
请解释我对这个例子的理解哪里错误:
使用具有域 x.com
的请求建立与中间件的 https 连接。中间盒的 IP 地址为 1.2.3.4 和 x.com
解析到该地址。使用 SNI,TLS 握手有 x.com
并且中间件返回对该域有效的证书。此连接上的所有消息都从客户端发送到中间件或从中间件发送到客户端。从客户端到中间件的应用程序级消息由中间件转发到不同连接上的源。从源到中间盒的消息被转发到客户端。如果要重用连接,满足上面讨论的两个条件是不够的。具体来说,对于域 y.com
的请求:如果y.com
解析为 1.2.3.4 并且中间件具有对 y.com
有效的证书,仍然可能存在问题。因为原始连接使用 x.com
进行 TLS 握手。并且由于握手仅在新连接开始时进行,因此无法建立 https 连接来获取 y.com
的证书。 。因此客户端错误地在同一连接上向 y.com
发送请求。 。中间件拒绝请求,因为与连接关联的证书对于 x.com
有效。 - 不是y.com
。 (x.com
证书仅对 x.com
有效,而 y.com
证书仅对 y.com
有效)。
最佳答案
据我所知,您的示例都不会触发 421。
是的,您是对的,连接需要同时证书中的 IP 地址和 SAN 字段才有效 - 如果没有这些,则不应重复使用连接。
那么什么会触发 421?据我所知,这主要是由于不同的 SSL/TLS 设置造成的。
例如:假设网站 A (siteA.example.com) 和网站 B (www.example.com) 都位于同一 IP 地址。假设网站 A 有一个 *.example.com 的通配符证书,而网站 B 有一个特定的证书。可能有几个原因:例如,它为主网站提供 EV 证书,而该证书不能是通配符证书。
因此证书 A 涵盖网站 A 和网站 B。IP 地址也是如此。因此,如果您连接到网站 siteA.example.com,然后尝试连接到 www.example.com,那么从技术上讲,根据 HTTP/2 标准,您可以重用该连接。但我们不希望这种情况发生,因为我们想使用我们的 EV 证书。因此服务器应该拒绝 421。现在,在这个示例中,网络服务器能够区分正确的主机并拥有该主机的有效证书,因此理论上可以在通配符证书下提供正确的内容,而不是发送 421 - 但由于没有为该虚拟主机定义通配符证书,因此不应该这样做。
其他示例包括您是否在不同主机上设置了不同的密码。例如,站点 A 具有 super 宽松的 HTTPS 配置,因为它不是真正安全的内容,并且他们甚至希望访问旧版浏览器,但站点 B 具有 super 安全配置,并且仅接受最新的 TLS 版本和强密码。在这里,您显然不希望他们重复使用相同的连接详细信息。请参阅here一个真实的例子。
此外,这只是某些浏览器的问题,具体取决于它们决定连接共享的方式。此页面显示了他们每个人执行此操作的不同之处(至少在撰写本博客文章时没有意识到此后发生的任何变化):https://daniel.haxx.se/blog/2016/08/18/http2-connection-coalescing/
另请注意,这会存在一些错误(例如: https://bugs.chromium.org/p/chromium/issues/detail?id=546991 )。最好的建议是:如果您不希望发生连接共享,请使用不同的 IP 地址和/或确保证书中没有重叠。
关于http-status-codes - http2:421 错误定向请求状态代码示例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41785803/
我正在通读 Windows Phone 7.5 Unleashed,有很多代码看起来像这样(在页面的代码隐藏中): bool loaded; protected override void OnNav
在cgi服务器中,我这样返回 print ('Status: 201 Created') print ('Content-Type: text/html') print ('Location: htt
我正在查看 esh(easy shell)的实现,无法理解在这种情况下什么是 22 和 9 信号。理想情况下,有一个更具描述性的常量,但我找不到列表。 最佳答案 信号列表及其编号(包括您看到的这两个)
我的Oozie Hive Action 永远处于运行模式。 oozie.log文件中没有显示错误。
我正在编写一个使用 RFCOMM 通过蓝牙连接到设备的 Android 应用程序。我使用 BluetoothChat 示例作为建立连接的基础,大部分时间一切正常。 但是,有时由于出现套接字已打开的消息
我有一个云调度程序作业,它应该每小时访问我的 API 以更新一些价格。这些作业大约需要 80 秒才能运行。 这是它的作用: POST https://www.example.com/api/jobs/
我正在 Tomcat 上访问一个简单的 JSP 页面: 但是当我使用 curl 测试此页面时,我得到了 200 响应代码而不是预期的 202: $ curl -i "http://localhos
有时 JAR-RS 客户端会发送错误的语法请求正文。服务器应响应 HTTP status 400 (Bad Request) , 但它以 HTTP status 500 (Internal Serve
我正在尝试通过 response.send() 发送一个整数,但我不断收到此错误 express deprecated res.send(status): Use res.sendStatus(sta
我已经用 Excel 和 Java 做过很多次了……这次我需要用 Stata 来做,因为保存变量更方便'labels .如何将 dataset_1 重组为下面的 dataset_2? 我需要转换以下
我正在创建一个应用程序,其中的对象具有状态查找功能。为了提供一些上下文,让我们使用以下示例。 帮助台应用程序,其中创建作业并通过以下工作流程移动: 新 - 工作已创建但未分配 进行中 - 分配给工作人
我想在 Keras 中运行 LSTM 并获得输出和状态。在 TF 中有这样的事情 with tf.variable_scope("RNN"): for time_step in range
有谁知道 Scala-GWT 的当前状态 项目? 那里的主要作者 Grzegorz Kossakowski 似乎退出了这个项目,在 Spring 中从事 scalac 的工作。 但是,在 interv
我正在尝试编写一个 super 简单的 applescript 来启动 OneDrive App , 或确保打开,当机器的电源设置为插入时,将退出,或确保关闭,当电源设置为电池时。 我无法找到如何访问
目前我正在做这样的事情 link.on('click', function () { if (link.attr('href') !== $route.current.originalPath
是否可以仅通过查看用户代理来检测浏览器上是否启用/禁用 Javascript。 如果是,我应该寻找什么。如果否,检测用户浏览器是否启用/禁用 JavaScript 的最佳方法是什么 最佳答案 不,没有
Spring 和 OSGi 目前的开发状况如何? 最近好像有点安静了。 文档的最新版本 ( http://docs.spring.io/osgi/ ) 来自 2009 年。 我看到一些声明 Sprin
我正在从主函数为此类创建一个线程,但即使使用 Thread.currentThread().interrupt() 中断它,输出仍然包含“Still Here”行。 public class Writ
为了满足并发要求,我想知道如何在 Godog 中的多个步骤之间传递参数或状态。 func FeatureContext(s *godog.Suite) { // This step is ca
我有一个UIButton子类,它不使用UIImage背景,仅使用背景色。我注意到的一件事是,当您设置按钮的背景图像时,有一个默认的突出显示状态,当按下按钮时,该按钮会稍微变暗。 这是我当前的代码。
我是一名优秀的程序员,十分优秀!