想用php代碼解壓,phpstudy怎麼解壓

本文目錄一覽:

如何通過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

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-26 21:09
下一篇 2024-11-26 21:09

相關推薦

  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • Python字元串寬度不限制怎麼打代碼

    本文將為大家詳細介紹Python字元串寬度不限制時如何打代碼的幾個方面。 一、保持代碼風格的統一 在Python字元串寬度不限制的情況下,我們可以寫出很長很長的一行代碼。但是,為了…

    編程 2025-04-29
  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • Python基礎代碼用法介紹

    本文將從多個方面對Python基礎代碼進行解析和詳細闡述,力求讓讀者深刻理解Python基礎代碼。通過本文的學習,相信大家對Python的學習和應用會更加輕鬆和高效。 一、變數和數…

    編程 2025-04-29
  • Python滿天星代碼:讓編程變得更加簡單

    本文將從多個方面詳細闡述Python滿天星代碼,為大家介紹它的優點以及如何在編程中使用。無論是剛剛接觸編程還是資深程序員,都能從中獲得一定的收穫。 一、簡介 Python滿天星代碼…

    編程 2025-04-29
  • 倉庫管理系統代碼設計Python

    這篇文章將詳細探討如何設計一個基於Python的倉庫管理系統。 一、基本需求 在著手設計之前,我們首先需要確定倉庫管理系統的基本需求。 我們可以將需求分為以下幾個方面: 1、庫存管…

    編程 2025-04-29
  • 寫代碼新手教程

    本文將從語言選擇、學習方法、編碼規範以及常見問題解答等多個方面,為編程新手提供實用、簡明的教程。 一、語言選擇 作為編程新手,選擇一門編程語言是很關鍵的一步。以下是幾個有代表性的編…

    編程 2025-04-29
  • Python實現簡易心形代碼

    在這個文章中,我們將會介紹如何用Python語言編寫一個非常簡單的代碼來生成一個心形圖案。我們將會從安裝Python開始介紹,逐步深入了解如何實現這一任務。 一、安裝Python …

    編程 2025-04-29
  • 怎麼寫不影響Python運行的長段代碼

    在Python編程的過程中,我們不可避免地需要編寫一些長段代碼,包括函數、類、複雜的控制語句等等。在編寫這些代碼時,我們需要考慮代碼可讀性、易用性以及對Python運行性能的影響。…

    編程 2025-04-29
  • Python愛心代碼動態

    本文將從多個方面詳細闡述Python愛心代碼動態,包括實現基本原理、應用場景、代碼示例等。 一、實現基本原理 Python愛心代碼動態使用turtle模塊實現。在繪製一個心形的基礎…

    編程 2025-04-29

發表回復

登錄後才能評論