今天在调取一家商城的页面信息时候,使用file_get_contents抑或curl:
代码如下:
都得到一片乱码,查看了许多内容,包括页面的header信息,发现原来页面使用了。
类似的信息,即content-encoding为gzip,即该站点开启了gzip压缩。这里的解决方案有多种,当然如果你使用file_get_contents的话,可以这样修改:
代码如下:
或者使用curl来完成:
代码如下:
etopt($curl,CURLOPT_RETURNTRANSFER,1);
curl_setopt($curl,CURLOPT_CONNECTTIMEOUT,10);
if($gzip) curl_setopt($curl,CURLOPT_ENCODING,"gzip"); // 关键在这里
$content = curl_exec($curl);
curl_close($curl);
return $content;
}
同时,参考手册上面的解法,还可以对保存gzip类型的字符串进行处理如下:
代码如下:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。