好得很程序员自学网
  • 首页
  • 后端语言
    • C#
    • PHP
    • Python
    • java
    • Golang
    • ASP.NET
  • 前端开发
    • Angular
    • react框架
    • LayUi开发
    • javascript
    • HTML与HTML5
    • CSS与CSS3
    • jQuery
    • Bootstrap
    • NodeJS
    • Vue与小程序技术
    • Photoshop
  • 数据库技术
    • MSSQL
    • MYSQL
    • Redis
    • MongoDB
    • Oracle
    • PostgreSQL
    • Sqlite
    • 数据库基础
    • 数据库排错
  • CMS系统
    • HDHCMS
    • WordPress
    • Dedecms
    • PhpCms
    • 帝国CMS
    • ThinkPHP
    • Discuz
    • ZBlog
    • ECSHOP
  • 高手进阶
    • Android技术
    • 正则表达式
    • 数据结构与算法
  • 系统运维
    • Windows
    • apache
    • 服务器排错
    • 网站安全
    • nginx
    • linux系统
    • MacOS
  • 学习教程
    • 前端脚本教程
    • HTML与CSS 教程
    • 脚本语言教程
    • 数据库教程
    • 应用系统教程
  • 新技术
  • 编程导航
    • 区块链
    • IT资讯
    • 设计灵感
    • 建站资源
    • 开发团队
    • 程序社区
    • 图标图库
    • 图形动效
    • IDE环境
    • 在线工具
    • 调试测试
    • Node开发
    • 游戏框架
    • CSS库
    • Jquery插件
    • Js插件
    • Web框架
    • 移动端框架
    • 模块管理
    • 开发社区
    • 在线课堂
    • 框架类库
    • 项目托管
    • 云服务

当前位置:首页>后端语言>PHP
<tfoot draggable='sEl'></tfoot>

php解压gz效率 rarphp文件怎么解压

很多站长朋友们都不太清楚php解压gz效率,今天小编就来给大家整理php解压gz效率,希望对各位有所帮助,具体内容如下:

本文目录一览: 1、 PHP 实现文件压缩解压zip格式 2、 php如何解压?求简短一点的代码。 3、 怎样用php压缩解压rar,zip文件? 4、 php 如何解压压缩文件 5、 php-5.3.6.tar.gz和php-5.3.6.tar.bz2区别 6、 如何通过php实现zip文件解压操作 PHP 实现文件压缩解压zip格式

在php中,有时我们需要使用到压缩文件操作,压缩文件可以节省磁盘空间;且压缩文件更小,便于网络传输,效率高,下面我们就来了解php的压缩解压相关操作

在PHP中有一个ZipArchive类,专门用于文件的压缩解压相关操作

在ZipArchive类中主要使用到了如下方法:

第一个参数:要打开的压缩包文件

第二个参数:

ZIPARCHIVE::OVERWRITE 总是创建一个新的文件,如果指定的zip文件存在,则会覆盖掉

ZIPARCHIVE::CREATE 如果指定的zip文件不存在,则新建一个

ZIPARCHIVE::EXCL 如果指定的zip文件存在,则会报错

ZIPARCHIVE::CHECKCONS 对指定的zip执行其他一致性测试

上面就是ZipArchive的一些常用方法,下面来一些简单示例

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"><p><font 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>

<td><input name="todir" type="text" id="todir" value="__unzipfiles__" size="15">

(留空为本目录,必须有写入权限)</td>

</tr>

<tr>

<td>验证密码: </td>

<td><input name="password" type="password" id="password" size="15">

(源文件中设定的密码)</td>

</tr>

<tr>

<td><input name="myaction" type="hidden" id="myaction" value="dounzip"></td>

<td><input 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;$i<count($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</a><br>";

}

}

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]</a><br>";

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]<br><br>";

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 个文件.<br><br><br>";

}else{

echo "<br>$upfile[name] 不是 zip 文件.<br><br>";

}

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;i<elements.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 "正在删除文件...<br><br>";

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>完成.<br><br><input type='button' value='返回' onclick=\"window.location='$_SERVER[PHP_SELF]';\"><br><br>

<script language='javascript'>('完成.');</script>";

endif;

?>

</form>

</body>

</html>

怎样用php压缩解压rar,zip文件?

要用PHP压缩解压文件,常用的方法是调用命令行去执行解压缩操作

可以用exec() 、system()等函数调用shell命令

Linux下解压缩命令是tar [-cxtzjvfpPN] 文件与目录,tar命令可以压缩解压.tar、.gz、.tar.gz、.tgz、.bz2、.tar.bz2、.Z、.tar.Z、.zip这些类型的文件

Linux下默认无法使用rar格式的,要另外安装RAR for Linux,然后使用rar和unrar命令解压缩rar格式的压缩文件

php 如何解压压缩文件

解压缩文件是调用外面程序来实现的,比如下面的语句解压缩abc.tgz

system("tar xzf abc.tgz");

php-5.3.6.tar.gz和php-5.3.6.tar.bz2区别

从文件名可以看出,两个PHP的版本号是一样的。不同的是文件类型。GZ是UNIX系统中的压缩文件,ZIP的Gnu版本,功能和WINRAR一样压缩文件。bz2也是unix下常见的压缩文件格式,是由具有高压缩率的压缩工具bzip2生成,以后缀为.bz2结尾的压缩文件。|不同的是gz型的压缩文件的压缩工具为7-Zip

解压工具为WINZIP、WinMount。

如何通过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('</br>entry not found');

$entry->extract($extractTo); // extract to the current dir

}

rar_close($rar_file);

}

关于php解压gz效率的介绍到此就结束了,不知道本篇文章是否对您有帮助呢?如果你还想了解更多此类信息,记得收藏关注本站,我们会不定期更新哦。

查看更多关于php解压gz效率 rarphp文件怎么解压的详细内容...

声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://www.haodehen.cn/did254814
更新时间:2023-09-23   阅读:53次

上一篇: php实例上传txt代码的简单介绍

下一篇:php语言怎么玩 php语言入门

相关资讯

最新资料更新

  • 1.php闭包this php闭包函数使用场景
  • 2.php上传图片木马 php图片上传代码
  • 3.php用户资料转移 php迁移java
  • 4.腾讯php招聘 招聘 腾讯
  • 5.php扩展的路径 php常用扩展有哪些
  • 6.海康sdk只有php 海康sdk python
  • 7.php前端页面源码 php前端页面源码是多少
  • 8.php代码修改按钮大小 php内容修改
  • 9.php数学函数 php中函数的定义
  • 10.php类方法 php类方法访问变量
  • 11.php项目基本流程 php项目如何运行
  • 12.php微信爬虫 微信爬虫访问是什么
  • 13.php获取服务器环境 php获取服务器状态
  • 14.php内存管理垃圾回收 php的垃圾回收机制是怎样的
  • 15.php交叉报表 ureport 交叉报表
  • 16.php根据城市定位 php获取位置信息
  • 17.php解压gz效率 rarphp文件怎么解压
  • 18.php根据逗号分割 php分割文本
  • 19.iPad上装php iPad上装修建模app
  • 20.php网页老是跳转 php 网页跳转

CopyRight:2016-2025好得很程序员自学网 备案ICP:湘ICP备09009000号-16 http://www.haodehen.cn
本站资讯不构成任何建议,仅限于个人分享,参考须谨慎!
本网站对有关资料所引致的错误、不确或遗漏,概不负任何法律责任。
本网站刊载的所有内容(包括但不仅限文字、图片、LOGO、音频、视频、软件、程序等)版权归原作者所有。任何单位或个人认为本网站中的内容可能涉嫌侵犯其知识产权或存在不实内容时,请及时通知本站,予以删除。

网站内容来源于网络分享,如有侵权发邮箱到:kenbest@126.com,收到邮件我们会即时下线处理。
网站框架支持:HDHCMS   51LA统计 百度统计
Copyright © 2018-2025 「好得很程序员自学网」
[ SiteMap ]