function showimage($zip_file, $file_name) {
if (file_exists($zip_file)) {
$zip = zip_open($zip_file);
while ($zip_entry = zip_read($zip)) {
if (zip_entry_open($zip, $zip_entry, "r")) {
if (zip_entry_name($zip_entry) == $file_name) {
$theimg = zip_entry_read($zip_entry, zip_entry_filesize($zip_entry));
$theimg = imagecreatefromstring($theimg);
if ($theimg !== false) {
header('Content-Type: image/jpeg');
imagejpeg($theimg);
imagedestroy($theimg);
}
else { echo "Could not create image."; }
zip_entry_close($zip_entry);
}
}
else { echo "Could not open."; }
}
zip_close($zip);
}
else { echo "File not found."; }
}
我正在运行此函数以打开指定的 zip 文件,然后遍历内容以查找指定的文件名,然后从该文件创建图像而无需提取。我只是有点好奇这个过程的系统密集程度如何,以及是否有一种更简洁/更直接的方式可以在 zip 存档中查找文件,而无需循环查看名称是否与给定的文件名匹配。假设它存在,是否可以直接从具有给定名称的 zip 文件中调用文件?
上面的代码有效......我想我只是想看看如何做得更好。如果这是有道理的。