用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

PHP执行Linux命令实现文件压缩

时间:2015-01-23  来源:西部数据  作者:西部数据

用PHP调用Linux的命令行,执行压缩命令,OK,马上行动.

拆分成3个txt文件 分别是wow_1.txt wow_2.txt 和 wow_3.txt  全部放到 Exl_file 目录下,代码如下:

$outputs=array();

用php的exec执行Linux命令,括号里的字符串就是你在Linux命令窗口里敲的命令;第二个参数是  linux执行该命令后返回的结果数组;linux执行返回的每一条结果依次存入该数组,第三个参数是结果,如果执行成功,则Linux返回结果值为0,如果执行失败,则结果值不为0,代码如下:

  1. exec("zip ./Exl_file/wow.zip ./Exl_file/wow_1.txt ./Exl_file/wow_2.txt ./Exl_file/wow_3.txt",$outputs,$rc); 
  2. if($rc!=0){ 
  3.     foreach ($outputs as $ko=>$vo){ 
  4.         echo "$vo<br/>"
  5.     } 
  6. }else
  7.     $zipfile='./Exl_file/wow.zip'
  8.          
  9.     //文件下载  输出后删除相关文件 
  10.     } 

你可以把  if($rc!=0)  改成  if(1==1)  查看Linux执行命令返回的结果行,如下图代码:

  1. adding: Exl_file/wow_1.txt (deflated 96%) 
  2. adding: Exl_file/wow_2.txt (deflated 97%) 
  3. adding: Exl_file/wow_3.txt (deflated 97%) 

可以看到执行返回的信息全部输入到了 $outputs 数组中,*.zip文件生成成功,php提供了system(),exec(),passthru()这几个函数来调用外部的命令,他们的区别:

system() 输出并返回最后一行shell结果.

exec() 不输出结果,返回最后一行shell结果,所有结果可以保存到一个返回的数组里面.

passthru() 只调用命令,把命令的运行结果原样地直接输出到标准输出设备上.

相同点:都可以获得命令执行的状态码,一个php调用zip实现方法,这个在windows中的,#upload.php,代码如下:

  1. <table border='0' > 
  2.      
  3.     <form ENCTYPE="multipart/form-data" action="upsave.php" method="post"
  4.      
  5.     <tr> 
  6.      
  7.     <td>如果是*.ZIP的文件会被自动解压缩<br> 
  8.      
  9.     <INPUT NAME="MyFile" TYPE="File" size="50"
  10.      
  11.     </td> 
  12.      
  13.     </tr> 
  14.      
  15.     <tr> 
  16.      
  17.     <td colspan='2' align="center"
  18.      
  19.     <input type="Submit" value=" 上传 " class=iwhite> 
  20.      
  21.     <input type="reset" value=" 重填 " class=iwhite> 
  22.      
  23.     </td> 
  24.      
  25.     </tr> 
  26.      
  27.     </table> 
  28.      
  29.     </body> 
  30.      
  31.     </html> 
  32.      
  33.     <? 
  34.      
  35.     //upsave.php 
  36.      
  37.     //保存上传的文件 
  38.      
  39.     $filename="$MyFile_name"
  40.      
  41.     copy$MyFile,"$filename"); 
  42.      
  43.     unlink($MyFile); 
  44.      
  45.     //判断是否是ZIP文件 
  46.      
  47.     $expand_name=explode".",$filename); 
  48.      
  49.     if$expand_name[1] == "zip" or $expand_name[1] == "ZIP") 
  50.      
  51.     { 
  52.      
  53.     $str="pkunzip.exe -e $filename "
  54.      
  55.     exec$str); 
  56.      
  57.     unlink($filename); 
  58.      
  59.     } 
  60.      
  61. ?> 
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门