要一个php脚本,能够解压php空间里的zip文件。

作者&投稿:赞垄 (若有异议请与网页底部的电邮联系)
PHP-php生成zip压缩文件如何给该文件加解压缩密码~

".$i++." 此文件已被跳过,原因:文件过大, -> ".iconv("gb2312","utf-8",$file_name)."
"; } } //关闭当前 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 "
解压完毕!,本次解压花费:$thistime 秒。";}$size = get_zip_originalsize('20131101.zip','temp/');?>

要用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格式的压缩文件

呵呵 简单啊 一个文件就可以了。。。
自己记得修改密码。 默认是123456 你可以自己找找里面有没有外连,
搜索http 保证安全。

-------------------------------------------------------------------

<?php

//验证密码
$password = "123456";

?>
<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文件程序 V1.0</font></p>
<p>使用方法:把zip文件通过FTP上传到本文件相同的目录下,选择zip文件;或直接点击“浏览...”上传zip文件。</p>
<p>颓废音乐:http://www.flashzx.net</p>
<p>转载请注明:本程序由 <a href="http://www.flashzx.net/" target="_blank">颓废</a>提供,作者:颓废</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>
";
}
}

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

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 "
正在解压: <input name='dfile[]' type='checkbox' value='$upfile[name]' ".($checked?"checked":"")."> $upfile[name]

";
if(preg_match('/\.zip$/mis',$upfile[name])){
$result=$z->Extract($upfile[tmp_name],$_POST["todir"]);
if($result==-1){
echo "
文件 $upfile[name] 错误.
";
}
echo "
完成,共建立 $z->total_folders 个目录,$z->total_files 个文件.

";
}else{
echo "
$upfile[name] 不是 zip 文件.

";
}
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 "
请选择或上传文件.
";
}
?>
<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 "正在删除文件...

";
if(is_array($dfile)){
for($i=count($dfile)-1;$i>=0;$i--){
if(is_file($dfile[$i])){
if(@unlink($dfile[$i])){
echo "已删除文件: $dfile[$i]
";
}else{
echo "删除文件失败: $dfile[$i]
";
}
}else{
if(@rmdir($dfile[$i])){
echo "已删除目录: $dfile[$i]
";
}else{
echo "删除目录失败: $dfile[$i]
";
}
}

}
}
echo "
完成.

<input type='button' value='返回' onclick=\"window.location='$_SERVER[PHP_SELF]';\">

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

endif;

?>
</form>
</body>
</html>
---------------------------------------------------------------
把中间的代码复制下来,然后用记事本另存为 jieya.php ,
上传到和zip一个目录下,打开这个地址,选择一下,目录记得也要写,
写上密码就按解压就可以了,十分方便简单,
转载自: http://flashzx.net

康盛出名吧?DZ的出品公司 下它的uchome,在source文件夹里有个class_zip文件夹,里边的zip类很好用,dz论坛程序里也有,不过估计是一样的。


php文件是网页脚本,能用什么软件打开和编辑?
结论:要打开php文件,实际上并不需要特定的软件,因为它们本质上是网页脚本。以下是打开和理解php文件的方法:首先,php文件并非需要“打开”以查看其内容,而是可能由于下载错误,我们收到的是一个包含php代码的网页。当遇到这种情况,使用记事本(右键选择"打开方式" > "记事本")就可以查看到文件中的...

php可以做什么
php是一种通用开源脚本语言,它主要应用于以下几个方面:1、制作网站:php最简单的应用就是制作网站,包括数据库类操作、社区、系统和管理。2、写爬虫:写爬虫,也就是我们说的数据采集,虽然不是php的强项,但只要你的php技术足够好,也是可以用php来写的。3、辅助开发:可以用php来辅助其他的东西来...

php的一个脚本怎么写?
php#订单个数$sum = 0;while(1){#查询语句$sql = "...";mysql_query($sql);$res = mysql_fetch_array();...#获取查询结果的长度$sumTmp = count($res);#比较长度大小if($sumTmp > $sum){ \/\/当前长度大于sum时,提取最后sumTmp一条记录}$sum = $sumTmp;#间隔60秒sleep(60);...

php能做哪些东西
PHP能做的东西非常广泛,主要包括以下几个方面:1. 网站开发 PHP最广泛的应用就是网站开发。它可以用来创建各种类型的网站,包括企业官网、博客、社交网站、电子商务网站等。PHP与HTML、CSS等前端技术结合,可以实现网页的交互性和动态内容展示。2. Web应用程序开发 PHP可以用来开发复杂的Web应用程序。无论...

要一个php脚本,能够解压php空间里的zip文件。
把中间的代码复制下来,然后用记事本另存为 jieya.php ,上传到和zip一个目录下,打开这个地址,选择一下,目录记得也要写,写上密码就按解压就可以了,十分方便简单,转载自: http:\/\/flashzx.net 已赞过 已踩过< 你对这个回答的评价是? 评论 收起

php是什么语言
PHP是一种脚本语言。PHP是一种广泛用于Web开发的服务器端脚本语言。以下是关于PHP的详细解释:1. PHP的基本定义:PHP是一种嵌入式语言,它可以在多种类型的服务器上运行,用于生成动态网页内容。PHP代码可以嵌入到HTML中,并通过Web服务器进行解释和执行。这种语言在Web开发领域非常受欢迎,因为它具有广泛...

php类型有哪些
PHP的类型主要包括以下几种:1. 脚本语言类型 PHP作为一种脚本语言,被广泛用于网页开发。它能够嵌入到HTML中,通过服务器端解释执行,生成动态网页内容。2. 面向对象类型 PHP是一种支持面向对象的编程语言。它提供了类和对象的概念,允许开发者创建可重用和模块化的代码。通过面向对象编程,可以更好地...

php有哪些特点
PHP是一种广泛使用的服务器端脚本语言,它具有以下几个特点:1. 开源免费 PHP是一种开源免费的语言,任何人都可以免费使用、修改和分发它。这使得PHP成为了许多网站和应用程序的首选语言。2. 跨平台性 PHP可以在多种操作系统上运行,包括Windows、Linux、Unix等。这使得开发人员可以在不同的平台上开发和...

php是什么格式
PHP是一种服务器端脚本语言,其文件通常以特定的格式呈现,也就是我们通常所说的脚本文件格式。这种格式的文件通常保存在扩展名为“.php”的文件中,而文件中的代码则在服务器上执行。其主要被用于网页开发中,嵌入到HTML文档中,以创建动态网页。以下是关于PHP格式的 一、PHP文件的基本结构 PHP文件通常...

php是什么语言脚本
是一种通用开源脚本语言。PHP是在服务器端执行的脚本语言,与C语言类似,是常用的网站编程语言。而且PHP独特的语法混合了C、Java、Perl以及PHP自创的语法。脚本语言又被称为扩建的语言,或者动态语言,是一种编程语言,用来控制软件应用程序,脚本通常以文本(如ASCII)保存,只在被调用时进行解释或编译。

潍坊市19173184377: 要一个php脚本,能够解压php空间里的zip文件.
柯澜止咳: 康盛出名吧?DZ的出品公司 下它的uchome,在source文件夹里有个class_zip文件夹,里边的zip类很好用,dz论坛程序里也有,不过估计是一样的.

潍坊市19173184377: 推荐我一个php空间 可以在线解压的 -
柯澜止咳: PHP在线解压缩工具,非cPanel用户必备2007-06-10 07:17终于找到几款好用的php在线解压缩工具了!如果你的空间不是通过cPanel管理的,那么强力推荐你使用,特别是国内用户.要解决的问题:XOOPS程序以及module的文件通常都很多...

潍坊市19173184377: tomcat可以运行php吗 -
柯澜止咳: tomcat可以运行php,不过需要配置一下.方法如下:将php解压到tomcat的根目录下,将文件夹名字改为php 把php.exe所在的路径加入到path中 将php.ini-development 复制一份.改名php.ini 打开 extension_dir = "ext" 这个选项 修改cgi.force_...

潍坊市19173184377: linux系统中PHP写了一个解压功能ZipArchive::extractTo():Permission denied?求大家能够协助小弟一下! -
柯澜止咳: 应该是你 extractTo 所指定的解压目录没有权限写入.如果你的这个脚本是在WEB中运行,那一般是以Apache、Nobody等身份运行的,所以要检查你的解压目录是否有这些用户写入的权限,而且要保证该目录的所有上级目录都有该用户的执行权限(即可以cd 进去).为了简单起见,你可以将这个解压目录放到一个大家都可写的目录,虽然这样会有一些安全风险.

潍坊市19173184377: PHP下载zip文件到本地并解压 -
柯澜止咳: 下载用socket,或者开了allow_url_fopen 直接用file 解压zip用自带的zip库即可 之前写过的一个php的离线下载 http://www.ifuns.cn/_test/download.html zip解压看手册,就那几个函数

潍坊市19173184377: php文件使用什么软件打开? -
柯澜止咳: 诸如.php、.perl、htm等许多程序设计语言源代码文件,其实都是文本格式的,所以完全可以采用记事本打开!不过采用记事本打开以后一般不容易分析源代码.也可以使用 ultraedit, editplus, Notepad++, Dreamweaver, Netbeans eclipse 等软件.php可以用文本编辑器(如记事本、emeditor、phpedit等)打开.如果要运行它得搭建相应的php环境和web服务支持才行.

潍坊市19173184377: PHP的解压缩函数怎么用?
柯澜止咳: 在你的PHP安装根目录下,找到php.ini并打开,查找;extension=php_zip.dll,将这行指令前面的";"删掉,就表示开启压缩功能... 如果你的虚拟空间不能用压缩功能那表示空间服务商没有开启这个功能

潍坊市19173184377: PHP文件怎么打开?
柯澜止咳: PHP是一个基于服务端来创建动态网站的脚本语言,全称Personal Home Page,您可以用PHP和HTML生成网站主页.当一个访问者打开主页时,服务端便执行PHP的命令并将执行结果发送至访问者的浏览器中,这类似于ASP和CoildFusion,...

潍坊市19173184377: window8怎么配置nginx -
柯澜止咳: 工具原料:电脑+win8+php环境 window8配置nginx方法如下: 1、首先需要准备的应用程序包. nginx:nginx/Windows-1.0.4php:php-5.2.16-nts-Win32-VC6-x86.zip (nginx下php是以FastCGI的方式运行,所以我们下载非线程安全也就是nts的php...

潍坊市19173184377: 如何在java程序中调用php文件 -
柯澜止咳: 安装和配置PHP/Java桥 最新的PHP/Java桥zip包可在sourceforge .net/ projects/ php-java-bridge/下载到,安装过程依赖于选择哪个Java平台通过这座桥与PHP脚本交互.◆对于J2SE,安装非常简单:◆安装J2SE 1.6或更高版本 ◆安装PHP 5.1.4...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网