[英]PHP handles a zip file as if it's empty
这是我正在使用的代码的精简版本。
$url = "http://server.com/getDaFile";
//Get the file from the server
$zip_file_contents = file_get_contents($url);
//Write file to disk
file_put_contents("file.zip", $zip_file_contents);
//open zip file
$zip = zip_open("file.zip");
if(is_resource($zip))
{
while($zip_entry = zip_read($zip))
{
if(zip_entry_open($zip, $zip_entry, 'r'))
{
//Read the whole file
$buf = zip_entry_read($zip_entry, zip_entry_filesize($zip_entry));
/*
Do stuff with $buf!!!
*/
zip_entry_close($zip_entry);
}
}
zip_close($zip);
}
else
{
echo "Not a resource. Oh noes!\n";
}
因此:获取文件,将其保存到磁盘,解压缩以提取其中包含的文件,对文件进行处理。 这里的问题是,由于某种原因,我无法弄清楚, zip_read
返回FALSE
,好像无法读取ZIP存档中的文件。 $zip
确实包含资源,我已经检查了var_dump
。
令我感到奇怪的是,我使用顶部的URL将ZIP文件下载到PC上,手动将其上传到PHP服务器,并注释掉对file_get_contents
和file_put_contents
的调用,因此PHP使用本地版本。 当我这样做时, zip_read
可以在ZIP内正确找到正确数量的文件,并按需要进行处理。
我也尝试这样做: $zip = zip_open($url)
但是$zip
无法通过is_resource($zip)
检查。
我的代码显然有问题,因为该URL有效并返回了一个有效的ZIP存档。 它是什么?
所以我终于找到了问题所在。 遵循@diolemo的建议,我在十六进制编辑器中打开了服务器的ZIP存档。 这是我在顶部找到的,然后是常规的ZIP二进制数据: http : //pastebin.com/vQEXJtTN
事实证明,ZIP文件的实际内容中混入了一个PHP错误。 不确定如何解决此问题(但肯定知道它与HTTP标头有关),我尝试了此人的代码,而且,您知道我的代码现在可以正常工作了!
得到教训? 即使看起来没问题,也不要信任您的数据(7-Zip和Winrar都成功打开了文件)。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.