本文目錄一覽:
如何通過php實現zip文件解壓操作
rar文件解壓php沒有直接支持的,不過可以通過下載將非線程安全的dll然後扔到php的ext目錄下,之後按照下面的步驟操作即可。
打開php.ini.
加一行 extension=php_rar.dll
重啟web伺服器 和php
複製代碼
代碼如下:
public function _unzip($fileName,$extractTO){
$fileName = iconv(‘utf-8′,’gb2312’,”upload/zip/8月.rar”);
// echo $fileName . ‘/br’;
$extractTo = “upload/zip/TEST/”;
$rar_file = rar_open($fileName) or die(‘could not open rar’);
$list = rar_list($rar_file) or die(‘could not get list’);
// print_r($list);
foreach($list as $file) {
$pattern = ‘/\”.*\”/’;
preg_match($pattern, $file, $matches, PREG_OFFSET_CAPTURE);
$pathStr=$matches[0][0];
$pathStr=str_replace(“\””,”,$pathStr);
// print_r($pathStr);
$entry = rar_entry_get($rar_file, $pathStr) or die(‘/brentry not found’);
$entry-extract($extractTo); // extract to the current dir
}
rar_close($rar_file);
}
php如何解壓?求簡短一點的代碼。
?php
//驗證密碼
$password = “123”;
?
html
head
meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″
title在線ZIP解壓程序/title
style type=”text/css”
!–
body,td{
font-size: 14px;
color: #000000;
}
a {
color: #000066;
text-decoration: none;
}
a:hover {
color: #FF6600;
text-decoration: underline;
}
—
/style
/head
body
form name=”myform” method=”post” action=”?=$_SERVER[PHP_SELF];?” enctype=”multipart/form-data” onSubmit=”return check_uploadObject(this);”
?
if(!$_REQUEST[“myaction”]):
?
script language=”javascript”
function check_uploadObject(form){
if(form.password.value==”){
alert(‘請輸入密碼.’);
return false;
}
return true;
}
/script
table width=”100%” border=”0″ cellspacing=”0″ cellpadding=”4″
tr
td height=”40″ colspan=”2″ style=”color:#FF9900″pfont color=”#FF0000″在線解壓ZIP文件程序/font/p
p使用方法:把zip文件通過FTP上傳到本文件相同的目錄下,選擇zip文件;或直接點擊「瀏覽…」上傳zip文件。/p
p解壓的結果保留原來的目錄結構。/p
p /p/td
/tr
tr
td width=”11%”選擇ZIP文件: /td
td width=”89%”select name=”zipfile”
option value=”” selected- 請選擇 -/option
?
$fdir = opendir(‘./’);
while($file=readdir($fdir)){
if(!is_file($file)) continue;
if(preg_match(‘/\.zip$/mis’,$file)){
echo “option value=’$file’$file/option\r\n”;
}
}
?
/select/td
/tr
tr
td width=”11%” nowrap或上傳文件: /td
td width=”89%”input name=”upfile” type=”file” id=”upfile” size=”20″/td
/tr
tr
td解壓到目錄: /td
tdinput name=”todir” type=”text” id=”todir” value=”__unzipfiles__” size=”15″
(留空為本目錄,必須有寫入許可權)/td
/tr
tr
td驗證密碼: /td
tdinput name=”password” type=”password” id=”password” size=”15″
(源文件中設定的密碼)/td
/tr
tr
tdinput name=”myaction” type=”hidden” id=”myaction” value=”dounzip”/td
tdinput type=”submit” name=”Submit” value=” 解 壓 “/td
/tr
/table
?
elseif($_REQUEST[“myaction”]==”dounzip”):
class zip
{
var $total_files = 0;
var $total_folders = 0;
function Extract ( $zn, $to, $index = Array(-1) )
{
$ok = 0; $zip = @fopen($zn,’rb’);
if(!$zip) return(-1);
$cdir = $this-ReadCentralDir($zip,$zn);
$pos_entry = $cdir[‘offset’];
if(!is_array($index)){ $index = array($index); }
for($i=0; $index[$i];$i++){
if(intval($index[$i])!=$index[$i]||$index[$i]$cdir[‘entries’])
return(-1);
}
for ($i=0; $i$cdir[‘entries’]; $i++)
{
@fseek($zip, $pos_entry);
$header = $this-ReadCentralFileHeaders($zip);
$header[‘index’] = $i; $pos_entry = ftell($zip);
@rewind($zip); fseek($zip, $header[‘offset’]);
if(in_array(“-1”,$index)||in_array($i,$index))
$stat[$header[‘filename’]]=$this-ExtractFile($header, $to, $zip);
}
fclose($zip);
return $stat;
}
function ReadFileHeader($zip)
{
$binary_data = fread($zip, 30);
$data = unpack(‘vchk/vid/vversion/vflag/vcompression/vmtime/vmdate/Vcrc/Vcompressed_size/Vsize/vfilename_len/vextra_len’, $binary_data);
$header[‘filename’] = fread($zip, $data[‘filename_len’]);
if ($data[‘extra_len’] != 0) {
$header[‘extra’] = fread($zip, $data[‘extra_len’]);
} else { $header[‘extra’] = ”; }
$header[‘compression’] = $data[‘compression’];$header[‘size’] = $data[‘size’];
$header[‘compressed_size’] = $data[‘compressed_size’];
$header[‘crc’] = $data[‘crc’]; $header[‘flag’] = $data[‘flag’];
$header[‘mdate’] = $data[‘mdate’];$header[‘mtime’] = $data[‘mtime’];
if ($header[‘mdate’] $header[‘mtime’]){
$hour=($header[‘mtime’]0xF800)11;$minute=($header[‘mtime’]0x07E0)5;
$seconde=($header[‘mtime’]0x001F)*2;$year=(($header[‘mdate’]0xFE00)9)+1980;
$month=($header[‘mdate’]0x01E0)5;$day=$header[‘mdate’]0x001F;
$header[‘mtime’] = mktime($hour, $minute, $seconde, $month, $day, $year);
}else{$header[‘mtime’] = time();}
$header[‘stored_filename’] = $header[‘filename’];
$header[‘status’] = “ok”;
return $header;
}
function ReadCentralFileHeaders($zip){
$binary_data = fread($zip, 46);
$header = unpack(‘vchkid/vid/vversion/vversion_extracted/vflag/vcompression/vmtime/vmdate/Vcrc/Vcompressed_size/Vsize/vfilename_len/vextra_len/vcomment_len/vdisk/vinternal/Vexternal/Voffset’, $binary_data);
if ($header[‘filename_len’] != 0)
$header[‘filename’] = fread($zip,$header[‘filename_len’]);
else $header[‘filename’] = ”;
if ($header[‘extra_len’] != 0)
$header[‘extra’] = fread($zip, $header[‘extra_len’]);
else $header[‘extra’] = ”;
if ($header[‘comment_len’] != 0)
$header[‘comment’] = fread($zip, $header[‘comment_len’]);
else $header[‘comment’] = ”;
if ($header[‘mdate’] $header[‘mtime’])
{
$hour = ($header[‘mtime’] 0xF800) 11;
$minute = ($header[‘mtime’] 0x07E0) 5;
$seconde = ($header[‘mtime’] 0x001F)*2;
$year = (($header[‘mdate’] 0xFE00) 9) + 1980;
$month = ($header[‘mdate’] 0x01E0) 5;
$day = $header[‘mdate’] 0x001F;
$header[‘mtime’] = mktime($hour, $minute, $seconde, $month, $day, $year);
} else {
$header[‘mtime’] = time();
}
$header[‘stored_filename’] = $header[‘filename’];
$header[‘status’] = ‘ok’;
if (substr($header[‘filename’], -1) == ‘/’)
$header[‘external’] = 0x41FF0010;
return $header;
}
function ReadCentralDir($zip,$zip_name){
$size = filesize($zip_name);
if ($size 277) $maximum_size = $size;
else $maximum_size=277;
@fseek($zip, $size-$maximum_size);
$pos = ftell($zip); $bytes = 0x00000000;
while ($pos $size){
$byte = @fread($zip, 1); $bytes=($bytes 8) | ord($byte);
if ($bytes == 0x504b0506 or $bytes == 0x2e706870504b0506){ $pos++;break;} $pos++;
}
$fdata=fread($zip,18);
$data=@unpack(‘vdisk/vdisk_start/vdisk_entries/ventries/Vsize/Voffset/vcomment_size’,$fdata);
if ($data[‘comment_size’] != 0) $centd[‘comment’] = fread($zip, $data[‘comment_size’]);
else $centd[‘comment’] = ”; $centd[‘entries’] = $data[‘entries’];
$centd[‘disk_entries’] = $data[‘disk_entries’];
$centd[‘offset’] = $data[‘offset’];$centd[‘disk_start’] = $data[‘disk_start’];
$centd[‘size’] = $data[‘size’]; $centd[‘disk’] = $data[‘disk’];
return $centd;
}
function ExtractFile($header,$to,$zip){
$header = $this-readfileheader($zip);
if(substr($to,-1)!=”/”) $to.=”/”;
if($to==’./’) $to = ”;
$pth = explode(“/”,$to.$header[‘filename’]);
$mydir = ”;
for($i=0;$icount($pth)-1;$i++){
if(!$pth[$i]) continue;
$mydir .= $pth[$i].”/”;
if((!is_dir($mydir) @mkdir($mydir,0777)) || (($mydir==$to.$header[‘filename’] || ($mydir==$to $this-total_folders==0)) is_dir($mydir)) ){
@chmod($mydir,0777);
$this-total_folders ++;
echo “input name=’dfile[]’ type=’checkbox’ value=’$mydir’ checked a href=’$mydir’ target=’_blank’目錄: $mydir/abr”;
}
}
if(strrchr($header[‘filename’],’/’)==’/’) return;
if (!($header[‘external’]==0x41FF0010)!($header[‘external’]==16)){
if ($header[‘compression’]==0){
$fp = @fopen($to.$header[‘filename’], ‘wb’);
if(!$fp) return(-1);
$size = $header[‘compressed_size’];
while ($size != 0){
$read_size = ($size 2048 ? $size : 2048);
$buffer = fread($zip, $read_size);
$binary_data = pack(‘a’.$read_size, $buffer);
@fwrite($fp, $binary_data, $read_size);
$size -= $read_size;
}
fclose($fp);
touch($to.$header[‘filename’], $header[‘mtime’]);
}else{
$fp = @fopen($to.$header[‘filename’].’.gz’,’wb’);
if(!$fp) return(-1);
$binary_data = pack(‘va1a1Va1a1’, 0x8b1f, Chr($header[‘compression’]),
Chr(0x00), time(), Chr(0x00), Chr(3));
fwrite($fp, $binary_data, 10);
$size = $header[‘compressed_size’];
while ($size != 0){
$read_size = ($size 1024 ? $size : 1024);
$buffer = fread($zip, $read_size);
$binary_data = pack(‘a’.$read_size, $buffer);
@fwrite($fp, $binary_data, $read_size);
$size -= $read_size;
}
$binary_data = pack(‘VV’, $header[‘crc’], $header[‘size’]);
fwrite($fp, $binary_data,8); fclose($fp);
$gzp = @gzopen($to.$header[‘filename’].’.gz’,’rb’) or die(“Cette archive est compress閑”);
if(!$gzp) return(-2);
$fp = @fopen($to.$header[‘filename’],’wb’);
if(!$fp) return(-1);
$size = $header[‘size’];
while ($size != 0){
$read_size = ($size 2048 ? $size : 2048);
$buffer = gzread($gzp, $read_size);
$binary_data = pack(‘a’.$read_size, $buffer);
@fwrite($fp, $binary_data, $read_size);
$size -= $read_size;
}
fclose($fp); gzclose($gzp);
touch($to.$header[‘filename’], $header[‘mtime’]);
@unlink($to.$header[‘filename’].’.gz’);
}
}
$this-total_files ++;
echo “input name=’dfile[]’ type=’checkbox’ value=’$to$header[filename]’ checked a href=’$to$header[filename]’ target=’_blank’文件: $to$header[filename]/abr”;
return true;
}
// end class
}
set_time_limit(0);
if ($_POST[‘password’] != $password) die(“輸入的密碼不正確,請重新輸入。”);
if(!$_POST[“todir”]) $_POST[“todir”] = “.”;
$z = new Zip;
$have_zip_file = 0;
function start_unzip($tmp_name,$new_name,$checked){
global $_POST,$z,$have_zip_file;
$upfile = array(“tmp_name”=$tmp_name,”name”=$new_name);
if(is_file($upfile[tmp_name])){
$have_zip_file = 1;
echo “br正在解壓: input name=’dfile[]’ type=’checkbox’ value=’$upfile[name]’ “.($checked?”checked”:””).” $upfile[name]brbr”;
if(preg_match(‘/\.zip$/mis’,$upfile[name])){
$result=$z-Extract($upfile[tmp_name],$_POST[“todir”]);
if($result==-1){
echo “br文件 $upfile[name] 錯誤.br”;
}
echo “br完成,共建立 $z-total_folders 個目錄,$z-total_files 個文件.brbrbr”;
}else{
echo “br$upfile[name] 不是 zip 文件.brbr”;
}
if(realpath($upfile[name])!=realpath($upfile[tmp_name])){
@unlink($upfile[name]);
rename($upfile[tmp_name],$upfile[name]);
}
}
}
clearstatcache();
start_unzip($_POST[“zipfile”],$_POST[“zipfile”],0);
start_unzip($_FILES[“upfile”][tmp_name],$_FILES[“upfile”][name],1);
if(!$have_zip_file){
echo “br請選擇或上傳文件.br”;
}
?
input name=”password” type=”hidden” id=”password” value=”?=$_POST[‘password’];?”
input name=”myaction” type=”hidden” id=”myaction” value=”dodelete”
input name=”按鈕” type=”button” value=”返回” onclick=”window.location=’?=$_SERVER[PHP_SELF];?’;”
input type=’button’ value=’反選’ onclick=’selrev();’ input type=’submit’ onclick=’return confirm(“刪除選定文件?”);’ value=’刪除選定’
script language=’javascript’
function selrev() {
with(document.myform) {
for(i=0;ielements.length;i++) {
thiselm = elements[i];
if(thiselm.name.match(/dfile\[]/)) thiselm.checked = !thiselm.checked;
}
}
}
alert(‘完成.’);
/script
?
elseif($_REQUEST[“myaction”]==”dodelete”):
set_time_limit(0);
if ($_POST[‘password’] != $password) die(“輸入的密碼不正確,請重新輸入。”);
$dfile = $_POST[“dfile”];
echo “正在刪除文件…brbr”;
if(is_array($dfile)){
for($i=count($dfile)-1;$i=0;$i–){
if(is_file($dfile[$i])){
if(@unlink($dfile[$i])){
echo “已刪除文件: $dfile[$i]br”;
}else{
echo “刪除文件失敗: $dfile[$i]br”;
}
}else{
if(@rmdir($dfile[$i])){
echo “已刪除目錄: $dfile[$i]br”;
}else{
echo “刪除目錄失敗: $dfile[$i]br”;
}
}
}
}
echo “br完成.brbrinput type=’button’ value=’返回’ onclick=\”window.location=’$_SERVER[PHP_SELF]’;\”brbr
script language=’javascript'(‘完成.’);/script”;
endif;
?
/form
/body
/html
如何用php解壓縮文件
您好,ZIP格式的可以
?php
//需開啟配置 php_zip.dll
//phpinfo();
header(“Content-type:text/html;charset=gb2312”);
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(‘temp/test.zip’,’temp/’);
?
大俠們,請問php在線解壓rar文檔 代碼,急需要………..謝謝!
PHP沒有處理rar壓縮的函數,自己編寫也不太現實,我建議在php裡面調用rar.exe來壓縮和解壓縮文件,調用rar.exe的時候參數比較多,可以運行rar.exe /?顯示,一般參數格式是:
用法: rar 命令 -開關 1 -開關 N 壓縮文件 文件…
@列表文件… 解壓路徑\
命令
a 添加文件到壓縮文件
c 添加壓縮文件注釋
cf 添加文件注釋
ch 改變壓縮文件參數
cw 寫入壓縮文件注釋到文件
d 刪除壓縮文件中的文件
e 解壓壓縮文件到當前目錄
例如要解壓當前文件夾下的a.rar的php語句是:
system(‘”C:\Program Files (x86)\WinRAR\rar.exe” e .\a.rar’);
如果你不是WIN7,或者安裝文件夾不同,注意更改文件位置。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/186038.html