php - net::ERR_HTTP2_PROTOCOL_ERROR 是关于什么的?

标签 php wordpress google-chrome curl http2

我目前正在开发一个网站,该网站在 Google Chrome 上触发了 net::ERR_HTTP2_PROTOCOL_ERROR 200 错误。我不确定到底是什么会引发此错误,我只是注意到它仅在以 HTTPS 访问网站时才会弹出。我不能 100% 确定它是相关的,但看起来它会阻止 JavaScript 正确执行。

例如,发生以下情况:

  1. 我正在通过 HTTPS 访问该网站

  2. 我的 Twitter feed 通过 https://publish.twitter.com 集成根本没有加载

  3. 我可以在控制台中注意到 ERR_HTTP2_PROTOCOL_ERROR

  4. 如果我删除加载 Twitter 源的代码,错误仍然存​​在

  5. 如果我通过 HTTP 访问该网站,Twitter 源会出现并且错误会消失

Google Chrome 是唯一触发该错误的网络浏览器:它在 Edge 和 Firefox 上运行良好。 (注意:我尝试使用 Safari,并且出现类似的 kcferrordomaincfnetwork 303 错误)

我想知道它是否可能与服务器返回的 header 有关,因为错误中提到了“200”,并且 404/500 页面没有触发任何内容。

问题是根本没有记录该错误。谷歌搜索给我的结果很少。此外,我注意到它出现在最近发布的 Google Chrome 中;该错误不会在 v.64.X 上出现,但在 v.75+ 上会出现(无论操作系统如何;我正在 Mac 上工作)。

<小时/>

可能与 Website OK on Firefox but not on Safari (kCFErrorDomainCFNetwork error 303) neither Chrome (net::ERR_SPDY_PROTOCOL_ERROR) 有关

<小时/>

进一步调查的结果如下:

  • 如果服务器返回 404 而不是 2XX,错误不会在完全相同的页面上弹出
  • 使用 HTTPS 证书在本地不会弹出错误
  • 在使用不同证书的不同服务器(均为 OVH)上弹出错误
  • 无论使用什么 PHP 版本,从 5.6 到 7.3(使用的框架:Cakephp 2.10)都会弹出错误

根据要求,下面是失败资源的返回 header ,即整个网页。即使错误在每个具有 HTTP header 200 的页面上触发,这些页面也始终会加载到客户端的浏览器上,但有时会缺少某个元素(在我的示例中为外部 Twitter 提要)。除整个文档本身外,“网络”选项卡上的所有其他 Assets 均已成功返回。 line that failed in console

Google Chrome header (有错误):

Chrome header

Firefox header (无错误):

Firefox header

控制台中的 curl --head --http2 请求返回以下成功:

HTTP/2 200 
date: Fri, 04 Oct 2019 08:04:51 GMT
content-type: text/html; charset=UTF-8
content-length: 127089
set-cookie: SERVERID31396=2341116; path=/; max-age=900
server: Apache
x-powered-by: PHP/7.2
set-cookie: xxxxx=0919c5563fc87d601ab99e2f85d4217d; expires=Fri, 04-Oct-2019 12:04:51 GMT; Max-Age=14400; path=/; secure; HttpOnly
vary: Accept-Encoding
<小时/>

尝试更深入地了解 chrome://net-export/和 https://netlog-viewer.appspot.com工具告诉我请求以 RST_STREAM 结尾:

t=123354 [st=5170]    HTTP2_SESSION_RECV_RST_STREAM
                      --> error_code = "2 (INTERNAL_ERROR)"
                      --> stream_id = 1

对于我在 this other post 中读到的内容,在 HTTP/2 中,如果客户端想要中止请求,它会发送 RST_STREAM。当服务器收到 RST_STREAM 时,它将停止向客户端发送 DATA 帧,从而停止响应(或下载) . 该连接仍可用于其他请求,并且与已中止的请求/响应并发的请求/响应可能会继续进行。 [...] 有可能当 RST_STREAM 从客户端传输到服务器时,请求的全部内容正在传输中并将到达客户端,客户端将丢弃它。然而,对于较大的响应内容,发送RST_STREAM可能有很好的机会在整个响应内容发送之前到达服务器,因此会节省带宽。"

所描述的行为与我观察到的行为相同。但这意味着浏览器是罪魁祸首,然后我不明白为什么它会发生在两个相同的页面上,一个有 200 header ,另一个有 404(如果我禁用 JS 也会一样)。

最佳答案

就我而言,情况是 - Web 服务器上没有剩余磁盘空间。

关于php - net::ERR_HTTP2_PROTOCOL_ERROR 是关于什么的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58215104/

相关文章:

php - Buddypress - 在标题中显示通知和配置文件(而不是 WP-admin 栏)

javascript - 如何做 HTML 谷歌多级条目?

php - Zend Framework 2 + Doctrine 2

php - Symfony2 中的本地化错误页面

php - 需要算法和实现帮助 - 比较 2 个文件

css - Zurb Foundation 基本字体大小?

html - 在 Wordpress 中使用视口(viewport)高度 (vh) 显示窗口高度百分比的 div 标签

javascript - 关于 jQuery 中 window.unload 的一些(奇怪?)问题

javascript - 添加 keydown 事件监听器可阻止我通过在 chrome 中按 F-12 检查 HTML 元素

javascript - jQuery ajax,附加数据有效但数据对另一端(计算机/用户)可见吗?