gpt4 book ai didi

Apache 代理导致 ERR_CONTENT_DECODING_FAILED 错误

转载 作者:行者123 更新时间:2023-11-28 23:12:51 31 4
gpt4 key购买 nike

我正在尝试配置从 Apache Web 服务器 (A) 到不同机器 (B) 上的另一个 Apache Web 服务器的反向代理。

通过我当前使用的配置,我能够访问位于服务器 B 上的网页,就好像它位于服务器 A 上一样,但是对某些 Assets 的请求不断导致 ERR_CONTENT_DECODING_FAILED(至少在 Chrome )。当我使用简单的重定向而不是代理时,这不会发生。

我浏览了请求和响应 header ,似乎文件传输一切正常:

要求:

GET /app1/assets/css/vendor.min.css?1470017050 HTTP/1.1
Host: some.host.address
...
Accept: text/css,*/*;q=0.1
Accept-Encoding: gzip, deflate, sdch

响应:

HTTP/1.1 200 OK
...
Vary: Accept-Encoding
Content-Encoding: gzip
Content-Type: text/css;charset=utf-8
Connection: Keep-Alive
Transfer-Encoding: chunked

我在服务器 A 上使用了以下配置:

ProxyPreserveHost on
ProxyPass "/app1/" "http://some.host.address:8080/app1/"
ProxyPassReverse "/app1/" "some.host.address:8080/app1/"
ProxyHTMLURLMap "http://some.host.address:8080" "/app1"

<Location /app1/>
ProxyPassReverse /app1/
ProxyHTMLEnable On
ProxyHTMLURLMap / /app1/
</Location>

最佳答案

ERR_CONTENT_DECODING_FAILED 错误发生在后端服务器使用压缩并且代理服务器在重写期间不处理缩减的内容。

我在 this wiki 中找到了有用的信息也在mod_proxy_html documentation .

我成功地尝试了以下(在重写之前膨胀):

ProxyHTMLEnable On
SetOutputFilter INFLATE;proxy-html;DEFLATE
ProxyHTMLURLMap / /app1/

然后在阅读 mod_proxy_html 页面上的评论(现已删除)后,我修改为(应该正确处理字符编码):

ProxyHTMLEnable On
RequestHeader unset Accept-Encoding
ProxyHTMLCharsetOut *
ProxyHTMLURLMap / /app1/
ProxyHTMLURLMap /app1/ /app1/

关于Apache 代理导致 ERR_CONTENT_DECODING_FAILED 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55035757/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com