在phpEnv集成的Nginx服务中,默认开启的Gzip压缩会对大部分响应内容进行压缩处理,但部分场景比如返回已压缩的zip文件、二进制流数据或者特定接口的原始数据时,需要针对特定URL关闭Gzip压缩,避免内容被二次压缩导致损坏。

配置文件定位
phpEnv的Nginx配置文件默认存放在安装目录下的nginx/conf文件夹中,针对单个站点的配置通常在vhost子目录下的对应站点配置文件中,也可以直接在nginx.conf的http块或者server块中添加全局配置。
核心配置指令说明
Nginx中控制Gzip压缩的核心指令如下:
gzip:全局开关,值为on或off,默认开启gzip_types:指定需要压缩的响应内容类型,比如text/plain text/css application/json等gzip_disable:通过正则匹配User-Agent来关闭压缩,不适合URL匹配场景location:用于匹配特定URL路径,在对应块中可以单独设置gzip off来关闭该路径下的压缩
针对特定URL关闭Gzip的配置方法
场景1:关闭单个固定URL的Gzip压缩
如果只需要关闭某个固定接口的压缩,比如/api/export/data,可以在站点的server块中添加如下配置:
location = /api/export/data {
# 关闭当前URL的Gzip压缩
gzip off;
# 其他接口相关配置,比如反向代理、fastcgi配置等
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi.conf;
}
场景2:关闭一类URL路径的Gzip压缩
如果需要关闭某个路径下所有请求的压缩,比如/download/目录下的所有文件,配置如下:
location /download/ {
# 关闭该路径下所有请求的Gzip压缩
gzip off;
# 静态文件根目录配置
root /www/wwwroot/example;
# 设置过期时间等配置
expires 7d;
}
场景3:通过正则匹配特定规则的URL关闭压缩
如果需要匹配符合特定规则的URL,比如所有以.zip或者.tar结尾的请求,配置如下:
location ~* .(zip|tar|gz|rar)$ {
# 关闭压缩
gzip off;
# 静态文件配置
root /www/wwwroot/example;
# 设置二进制文件下载头部
add_header Content-Type application/octet-stream;
}
配置生效步骤
修改完配置文件后,需要执行以下步骤让配置生效:
- 打开phpEnv控制面板,找到Nginx服务,点击重启按钮
- 如果控制面板没有重启选项,也可以进入phpEnv的Nginx目录,执行
nginx -s reload命令平滑重载配置 - 可以通过curl命令测试配置是否生效,执行
curl -I -H "Accept-Encoding: gzip" http://127.0.0.1/api/export/data,查看响应头中是否有Content-Encoding: gzip,如果没有则说明配置生效
注意事项
需要注意gzip off指令的优先级高于全局的gzip on配置,只要在特定location块中设置了该指令,对应URL的压缩就会被关闭,不会影响其他路径的正常压缩效果。另外如果站点同时使用了反向代理配置,需要确保gzip off指令放在代理配置之前,避免被其他指令覆盖。