仔細的研究了一下,原來用php寫的解壓程序效率比想象的還是高很多的,既然這麼好,干脆再優化一下後用到自己後台中,雖然現在大部分空間的控制面板中有壓縮和解壓這個功能,但是畢竟有時候有些麻煩。
做這個之前,沒有接觸過php壓縮這一塊,網上搜了一些,大多數都是php壓縮類、壓縮函數,少則幾百行,多的就幾千行代碼。這對於我這種新手來說很摸不到頭腦,再說我也不用這麼復雜的功能。最後參考函數手冊,理清楚了幾個相關的函數後,就明白了怎麼去整了。
記得要開啟 zip ,把 php.ini 中的 extension=php_zip.dll 前面的分號去掉。
源碼范例:
復制代碼 代碼如下:
<?php
//需開啟配置 php_zip.dll
//phpinfo();
header("Content-type:text/html;charset=utf-8");
function get_zip_originalsize($filename, $path) {
//先判斷待解壓的文件是否存在
if(!file_exists($filename)){
die("文件 $filename 不存在!");
}
$starttime = explode(' ',microtime()); //解壓開始的時間
//將文件名和路徑轉成windows系統默認的gb2312編碼,否則將會讀取不到
$filename = iconv("utf-8","gb2312",$filename);
$path = iconv("utf-8","gb2312",$path);
//打開壓縮包
$resource = zip_open($filename);
$i = 1;
//遍歷讀取壓縮包裡面的一個個文件
while ($dir_resource = zip_read($resource)) {
//如果能打開則繼續
if (zip_entry_open($resource,$dir_resource)) {
//獲取當前項目的名稱,即壓縮包裡面當前對應的文件名
$file_name = $path.zip_entry_name($dir_resource);
//以最後一個“/”分割,再用字符串截取出路徑部分
$file_path = substr($file_name,0,strrpos($file_name, "/"));
//如果路徑不存在,則創建一個目錄,true表示可以創建多級目錄
if(!is_dir($file_path)){
mkdir($file_path,0777,true);
}
//如果不是目錄,則寫入文件
if(!is_dir($file_name)){
//讀取這個文件
$file_size = zip_entry_filesize($dir_resource);
//最大讀取6M,如果文件過大,跳過解壓,繼續下一個
if($file_size<(1024*1024*6)){
$file_content = zip_entry_read($dir_resource,$file_size);
file_put_contents($file_name,$file_content);
}else{
echo "<p> ".$i++." 此文件已被跳過,原因:文件過大, -> ".iconv("gb2312","utf-8",$file_name)." </p>";
}
}
//關閉當前
zip_entry_close($dir_resource);
}
}
//關閉壓縮包
zip_close($resource);
$endtime = explode(' ',microtime()); //解壓結束的時間
$thistime = $endtime[0]+$endtime[1]-($starttime[0]+$starttime[1]);
$thistime = round($thistime,3); //保留3為小數
echo "<p>解壓完畢!,本次解壓花費:$thistime 秒。</p>";
}
$size = get_zip_originalsize('20131101.zip','temp/');
?>
測試解壓了一個300多KB的小文件,花了0.115秒,測試解壓了一個30多MB的(網頁文件,小文件比較多),花了20多秒。