Google Chrome对于Ajax调用返回ERR_HTTP2_SERVER_REFUSED_STREAM

问题描述

我遇到了旧版本似乎没有的Google Chrome 85问题。

我正在触发ajax调用,该调用上载文件以使其在Web服务器上进行处理。 此调用一个非常基本的多部分xhr POST请求,可以上传文件

出于某种原因,谷歌浏览器(和Firefox)拒绝接受来自网络服务器的响应。 Chrome开发工具在XHR请求的“状态”列中显示“(失败)net :: ERR_HTTP2_SERVER_REFUSED_STREAM”。但是我不知道为什么浏览器似乎拒绝该流...

我可以使用curl调试return&fetch HTTP标头,但是我不知道返回HTTP标头有什么问题,或者为什么Google Chrome(和其他浏览器)似乎拒绝该结果。

任何想法或建议如何调试这些HTTP标头以确保“有效性”?还是由于某些原因而被拒绝?

请求标头(从chrome devtools复制并粘贴):

:authority: www.redactedwebsite.com
:method: POST
:path: /cms/multi-tab-taggable-attachment/fa0acf6/add
:scheme: https
accept: application/json
accept-encoding: gzip,deflate,br
accept-language: nl,en-US;q=0.9,en;q=0.8,zh;q=0.7,zh-TW;q=0.6,zh-CN;q=0.5,de;q=0.4,ja;q=0.3
cache-control: no-cache
content-length: 5431100
content-type: multipart/form-data; boundary=----WebKitFormBoundarytN9UfBZY5RJtGVt0
cookie: PHPSESSID=9a7d2c08b9506a02c18f864fb09262a4
origin: https://www.redactedwebsite.com
referer: https://www.redactedwebsite.com/cms/page/27/edit
sec-fetch-dest: empty
sec-fetch-mode: cors
sec-fetch-site: same-origin
user-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_6) AppleWebKit/537.36 (KHTML,like Gecko) Chrome/85.0.4183.83 Safari/537.36
x-requested-with: XMLHttpRequest

卷曲显示的返回标题和正文如下:

HTTP/2 200
date: Thu,03 Sep 2020 19:21:37 GMT
server: Apache
x-powered-by: PHP/7.2.33
x-generation-time: 0,02101s
set-cookie: PHPSESSID=9a7d2c08b9506a02c18f864fb09262a4; path=/
vary: Accept-Encoding
content-encoding: gzip
content-length: 272
content-type: application/json
x-varnish: 565546302
age: 0
via: 1.1 varnish (Varnish/6.4)
accept-ranges: bytes

{"success":true,<and much more,redacted>}

我没有发现return或request标头有什么问题,我也不知道为什么XHR调用被Chrome阻止并给出:“(失败)net :: ERR_HTTP2_SERVER_REFUSED_STREAM”。

有什么想法吗?或在哪里可以调试或验证请求/返回标头的建议? 非常感谢!

干杯 B。

解决方法

对于来自 Google 的人来说,有更多原因的答案here

就我而言,我使用的是办公室 VPN。看起来 VPN 正在将 HTTP2 请求降级到 HTTP/1.1,结果服务器通过 ERR_HTTP2_SERVER_REFUSED_STREAM 拒绝了它们。

,

在您的特定情况下,这可能无济于事,但尽管如此,我还是要权衡一下:

我昨天在表单上张贴文件时遇到了完全相同的问题/错误消息。就我而言,该错误仅在文件大小超过10KB时出现,而在10KB以下的文件上传并没有造成问题。

在其他Web服务器上的同一表单显示上传相同的较大文件没有问题。这使我相信,至少在我看来,这是服务器端配置问题。

就我而言,今天它已自行解决。

,

后续行动:他们调查了发生此问题的地方,与我的网络托管提供商的支持团队联系。 正如@Maarten Cuypers指出的那样,这似乎是服务器端,因为他们承认了问题,并在24小时后解决了该问题。我没有对应用程序层进行任何更改。

不幸的是,我没有指示他们对服务器配置所做的更改,因此我无法发布答案...:-(

,

我花了 4 天时间在我的 wordpress 网站上处理同样的网络::ERR_HTTP2_SERVER_REFUSED_STREAM,仅在加载我的 Oxygen Builder 编辑模板时发生...

我做了所有人类知道的事情...... cmd netsh,重置网络,路由器,一切......我在使用另一台计算机时没有出现这个错误......只是我的桌面,我无意中使用了“管理我的设备”来自微软。

我刚刚切换回“使用本地帐户”

然后我的问题就消失了..

我不知道这是真正的原因还是一些奇怪的巧合,但我找不到任何其他帮助...希望这是一个真正的解决方案,您可能会发现它很有用。