phpzip 在打包成压缩包时,修改压缩包内文件的文件名

我使用的class_phpzip.php 插件打包zip,对class_phpzip.php 文件,增加了一个文件名数组,直接上代码,从代码里面看比较方便

<?php
# 
# PHPZip v1.2 by Sext (sext@neud.net) 2002-11-18
#   (Changed: 2003-03-01)
# 
# Makes zip archive
#
# Based on "Zip file creation class", uses zLib
#
#

class PHPZip{
	/**
		压缩ZIP文件
		@$FileList 		文件列表(array),只能压缩文件
		@$zipfilename	要保存到的zip文件路径,如:C:\123.zip
        @$FileListname   为依次对应$FileList文件列表的文件名(array),就是懒得改写$FileList,所以就直接增加一个变量
	*/
	function Zip($FileList, $zipfilename,$FileListname){
		if (@function_exists('gzcompress')){
			$curdir = getcwd();
			if (is_array($FileList)){	//如果是文件列表
				$filelist = $FileList;
			}else{
				$filelist = $this -> GetFileList($FileList);
			}
			
			if ((!empty($FileList)) && (!is_array($FileList)) && (file_exists($FileList))){	//单个文件
				chdir($FileList);
			}else{
				chdir($curdir);
			}
 
			if (count($filelist)>0){
				foreach($filelist as $key=>$filename){
					if (is_file($filename)){
						$fd = fopen ($filename, "r");
						$content = fread ($fd, filesize ($filename));
						fclose ($fd);
						if (is_array($FileList)) $filename = basename($filename);
						
						$filename = $key.$FileListname[$key];
						
						$filename = iconv("UTF-8","GB2312",$filename);
						
					//	因为中文名问题,所以进行修改编码
						
						
						$this -> addFile($content, $filename);
					}
				}
				$out = $this -> file();
				chdir($curdir);
				$fp = fopen($zipfilename, "w");
				fwrite($fp, $out, strlen($out));
				fclose($fp);
			}
			return 1;
		}else{
			return 0;
		}
	}
 
	function GetFileList($dir){
		if (file_exists($dir)){
			echo $dir;
			$args = func_get_args();
			$pref = $args[1];
			$dh = opendir($dir);
			while($files = readdir($dh)){
				if (($files!=".")&&($files!="..")){
					if (is_dir($dir.$files)){
						$curdir = getcwd();
						chdir($dir.$files);
						$file = array_merge($file, $this -> GetFileList("", "$pref$files/"));
						chdir($curdir);
					}
					else $file[]=$pref.$files;
				}
			}
			closedir($dh);
		}
		
		
		return $file;
	}
 
	var $datasec      = array();
	var $ctrl_dir     = array();
	var $eof_ctrl_dir = "\x50\x4b\x05\x06\x00\x00\x00\x00";
	var $old_offset   = 0;
 
	/**
	一个Unix时间戳转换成一个4字节的DOS日期和时间格式(日高两个字节,时间允许大小比较低两个字节)
	@param integer 	当前的Unix时间戳
	@return integer 一个4字节的DOS格式的当前日期
	@access private
	*/
	function unix2DosTime($unixtime = 0) {
		$timearray = ($unixtime == 0) ? getdate() : getdate($unixtime);
		if ($timearray['year'] < 1980) {
			$timearray['year']    = 1980;
			$timearray['mon']     = 1;
			$timearray['mday']    = 1;
			$timearray['hours']   = 0;
			$timearray['minutes'] = 0;
			$timearray['seconds'] = 0;
		}
		return (($timearray['year'] - 1980) << 25) | ($timearray['mon'] << 21) | ($timearray['mday'] << 16) |
		($timearray['hours'] << 11) | ($timearray['minutes'] << 5) | ($timearray['seconds'] >> 1);
	}
 
 
/**
	添加压缩文件
	@param string   文件的内容
	@param string   在归档文件中的文件名称(可包含路径)
	@param integer 	当前的时间戳
*/
 
	function addFile($data, $name, $time = 0){
		
		
		$name     = str_replace('\\', '/', $name);
 
		$dtime    = dechex($this->unix2DosTime($time));
		$hexdtime = '\x' . $dtime[6] . $dtime[7]
		. '\x' . $dtime[4] . $dtime[5]
		. '\x' . $dtime[2] . $dtime[3]
		. '\x' . $dtime[0] . $dtime[1];
		eval('$hexdtime = "' . $hexdtime . '";');
 
		$fr   = "\x50\x4b\x03\x04";
		$fr   .= "\x14\x00";            // ver needed to extract
		$fr   .= "\x00\x00";            // gen purpose bit flag
		$fr   .= "\x08\x00";            // compression method
		$fr   .= $hexdtime;             // last mod time and date
 
		// "local file header" segment
		$unc_len = strlen($data);
		$crc     = crc32($data);
		$zdata   = gzcompress($data);
		$c_len   = strlen($zdata);
		$zdata   = substr(substr($zdata, 0, strlen($zdata) - 4), 2); // fix crc bug
		$fr      .= pack('V', $crc);             // crc32
		$fr      .= pack('V', $c_len);           // compressed filesize
		$fr      .= pack('V', $unc_len);         // uncompressed filesize
		$fr      .= pack('v', strlen($name));    // length of filename
		$fr      .= pack('v', 0);                // extra field length
		$fr      .= $name;
 
		// "file data" segment
		$fr .= $zdata;
 
		// "data descriptor" segment (optional but necessary if archive is not
		// served as file)
		$fr .= pack('V', $crc);                 // crc32
		$fr .= pack('V', $c_len);               // compressed filesize
		$fr .= pack('V', $unc_len);             // uncompressed filesize
 
		// add this entry to array
		$this -> datasec[] = $fr;
		$new_offset        = strlen(implode('', $this->datasec));
 
		// now add to central directory record
		$cdrec = "\x50\x4b\x01\x02";
		$cdrec .= "\x00\x00";                // version made by
		$cdrec .= "\x14\x00";                // version needed to extract
		$cdrec .= "\x00\x00";                // gen purpose bit flag
		$cdrec .= "\x08\x00";                // compression method
		$cdrec .= $hexdtime;                 // last mod time & date
		$cdrec .= pack('V', $crc);           // crc32
		$cdrec .= pack('V', $c_len);         // compressed filesize
		$cdrec .= pack('V', $unc_len);       // uncompressed filesize
		$cdrec .= pack('v', strlen($name) ); // length of filename
		$cdrec .= pack('v', 0 );             // extra field length
		$cdrec .= pack('v', 0 );             // file comment length
		$cdrec .= pack('v', 0 );             // disk number start
		$cdrec .= pack('v', 0 );             // internal file attributes
		$cdrec .= pack('V', 32 );            // external file attributes - 'archive' bit set
		$cdrec .= pack('V', $this -> old_offset ); // relative offset of local header
		$this -> old_offset = $new_offset;
		$cdrec .= $name;
		$this -> ctrl_dir[] = $cdrec;
	}
 
 
/**
	文件印出来
	@return 字符串的压缩文件
*/
	function file(){
		$data    = implode('', $this -> datasec);
		$ctrldir = implode('', $this -> ctrl_dir);
		return $data.$ctrldir.$this -> eof_ctrl_dir.
		pack('v', sizeof($this -> ctrl_dir)). // total # of entries "on this disk"
		pack('v', sizeof($this -> ctrl_dir)). // total # of entries overall
		pack('V', strlen($ctrldir)).           // size of central dir
		pack('V', strlen($data)).              // offset to start of central dir
		"\x00\x00";                             // .zip file comment length
	}
}

?>

 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您想要先将多个文件打包压缩包,然后再将压缩包进行分片下载。以下是一种实现方式: 1. 首先,确保您的服务器上安装了zip扩展。您可以通过在PHP配置文件中取消注释 `extension=zip` 来启用该扩展。 2. 在服务器端,您可以创建一个PHP脚本来处理下载请求。首先,您需要将多个文件打包一个压缩包。您可以使用以下代码: ```php $files = array('/path/to/file1', '/path/to/file2', '/path/to/file3'); // 要打包文件路径数组 $zipname = '/path/to/your/zipfile.zip'; // 压缩包保存路径 $zip = new ZipArchive(); if ($zip->open($zipname, ZipArchive::CREATE) === TRUE) { foreach ($files as $file) { $filename = basename($file); $zip->addFile($file, $filename); } $zip->close(); } else { echo 'Failed to create zip file.'; exit; } ``` 这段代码会将指定的文件打包一个压缩包并保存到指定路径。 3. 接下来,您可以使用类似之前提到的代码来实现分片下载压缩包的功能。您只需要将文件路径更改为压缩包的路径即可。 ```php $file = '/path/to/your/zipfile.zip'; // 压缩包路径 $filename = 'filename.zip'; // 下载显示的文件名 $chunk_size = 1024 * 1024; // 分片大小,这里设置为1MB if (file_exists($file)) { header('Content-Description: File Transfer'); header('Content-Type: application/octet-stream'); header('Content-Disposition: attachment; filename="' . $filename . '"'); header('Expires: 0'); header('Cache-Control: must-revalidate'); header('Pragma: public'); header('Content-Length: ' . filesize($file)); // 打开文件进行分片下载 $handle = fopen($file, 'rb'); if ($handle) { while (!feof($handle)) { echo fread($handle, $chunk_size); ob_flush(); flush(); } fclose($handle); } exit; } else { echo 'File not found.'; } ``` 请确保将代码中的`/path/to/file1`、`/path/to/file2`、`/path/to/file3`替换为您实际的文件路径,并将`/path/to/your/zipfile.zip`替换为您希望生压缩包路径。 希望对您有所帮助!如有任何问题,请随提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值