启用CURLOPT_ENCODING为空字符串可让cURL自动解压gzip响应,PHP 5.6.0+支持该特性,推荐优先使用此方式实现自动解压缩,无需手动处理。
PHP处理cURL请求时,如果服务器返回的是gzip压缩的响应内容,可以通过cURL选项自动解压,也可以手动检测Content-Encoding头来判断是否需要解压。以下是具体实现方式。
从PHP 5.6.0开始,cURL扩展支持自动解压gzip和deflate编码的内容。只需在发起请求时设置CURLOPT_ENCODING为一个空字符串即可:
示例代码:
$ch = curl_init(); curl_setopt($ch, CURLOPT_URL, "https://httpbin.org/gzip"); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_ENCODING, ""); // 启用自动解压 $response = curl_exec($ch); curl_close($ch); // $response 已是解压后的文本 echo $response;
如果你需要控制解压逻辑或兼容旧版本PHP,可以手动获取响应头并判断是否使用了gzip压缩:
CURLOPT_HEADER和CURLOPT_NOBODY配合解析头信息curl_getinfo($ch, CURLINFO_CONTENT_ENCODING)获取编码类型gzdecode()函数解压原始数据示例代码:
$ch = curl_init(); curl_setopt($ch, CURLOPT_URL, "https://httpbin.org/gzip"); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_HEADER, false); curl_setopt($ch, CURLOPT_ENCODING, ""); // 仍建议开启自动解压 $response = curl_exec($ch); // 或者查看实际使用的编码 $encoding = curl_getinfo($ch, CURLINFO_CONTENT_ENCODING); if ($encoding === 'gzip') { $decoded = @gzdecode($response); if ($decoded !== false) { $response = $decoded; } } curl_close($ch); echo $response;
CURLOPT_ENCODING => "",让cURL自动处理压缩gzdecode会出错x-gzip,但cURL会统一识别为gzip基本上就这些。只要设置CURLOPT_ENCODING为空字符串,PHP的cURL就能自动处理gzip响应,开发中无需额外判断。手动检测仅用于特殊场景或调试用途。