如果后端已经设置了“content-encoding”标头,是否有任何聪明的方法可以欺骗 nginx 停止 gzip?
Nginx 配置为对 php fastcgi 后端的输出进行 gzip 压缩。
这在 99% 的情况下都很有效。
除了极少数情况外,php 会发送一个原始 gzip 压缩文件并附加一个Content-Encoding: gzip
header.
不幸的是,Nginx 会继续尝试第二次对该内容进行 gzip 压缩。
产生一个双content-encoding: gzip
content-encoding: gzip
标头和双编码 gzip 正文。
大多数现代浏览器都可以处理这个问题,比如 Firefox、Chrome。
IE8 不能,Safari 移动版不能,旧版 Safari 5 for Windows 不能 - 相反,它们会显示乱码的 gzip 压缩内容,因为它合并了内容编码标头,并且仅对 gzip 压缩正文进行一次解码。
感谢您的任何想法。
在 nginx.conf 中适用的地方(应该有一个 fastcgi_params 文件):
fastcgi_param HTTP_ACCEPT_ENCODING "";
这将禁用后端的编码。
我希望 Nginx 在此之后仍能提供编码内容。 (我不知道)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)