PHPZip 사용

WBOY
WBOY원래의
2016-07-25 08:42:25870검색
  1. class PHPZip
  2. {
  3. function Zip($dir, $zipfilename)
  4. {
  5. if (@function_exists('gzcompress'))
  6. {
  7. $curdir = getcwd();
  8. if (is_array($dir))
  9. {
  10. $filelist = $dir;
  11. }
  12. else
  13. {
  14. $filelist = $this -> GetFileList($dir);
  15. }
  16. if ((!empty($dir))&&(!is_array($dir))&&(file_exists($dir))) chdir($dir);
  17. else chdir($curdir);
  18. if (count($filelist)>0)
  19. {
  20. foreach($filelist as $filename)
  21. {
  22. if (is_file($filename))
  23. {
  24. $fd = fopen ($filename, "r");
  25. $content = fread ($fd, filesize ($filename));
  26. fclose ( $fd);
  27. if (is_array($dir)) $filename = basename($filename);
  28. $this -> addFile($content, $filename);
  29. }
  30. }
  31. $out = $this -> file();
  32. chdir($curdir);
  33. $fp = fopen($zipfilename, "w");
  34. fwrite($fp, $out, strlen($out));
  35. fclose($fp);
  36. }
  37. return 1;
  38. }
  39. else return 0;
  40. }
  41. function GetFileList($dir)
  42. {
  43. if (file_exists($dir))
  44. {
  45. $args = func_get_args();
  46. $pref = $args[1];
  47. $dh = opendir($dir );
  48. while($files = readdir($dh))
  49. {
  50. if (($files!=".")&&($files!=".."))
  51. {
  52. if (is_dir($dir.$files))
  53. {
  54. $curdir = getcwd();
  55. chdir($dir.$files);
  56. $file = array_merge($file , $this -> GetFileList("", "$pref$files/"));
  57. chdir($curdir);
  58. }
  59. else $file[]=$pref.$files;
  60. }
  61. }
  62. closeir($dh);
  63. }
  64. return $file;
  65. }
  66. var $datasec = array();
  67. var $ ctrl_dir = array();
  68. var $eof_ctrl_dir = "x50x4bx05x06x00x00x00x00";
  69. var $old_offset = 0;
  70. /**
  71. * Unix 타임스탬프를 4바이트 DOS 날짜 및 시간 형식으로 변환합니다(date
  72. *는 상위 2바이트, 시간은 규모 비교가 가능하도록 하위 2바이트).
  73. *
  74. * @param 정수 현재 Unix 타임스탬프
  75. *
  76. * @return 정수 4바이트 DOS 형식의 현재 날짜
  77. *
  78. * @access private
  79. */
  80. function unix2DosTime($unixtime = 0 ) {
  81. $timearray = ($unixtime == 0) ? getdate() : getdate($unixtime);
  82. if ($timearray['연도'] < 1980) {
  83. $timearray['연도'] = 1980;
  84. $timearray[' mon'] = 1;
  85. $timearray['mday'] = 1;
  86. $timearray['hours'] = 0;
  87. $timearray['분'] = 0;
  88. $timearray ['초'] = 0;
  89. } // 종료 if
  90. return (($timearray['year'] - 1980) << 25) | ($timearray['mon'] << 21) | ($timearray['mday'] << 16) |
  91. ($timearray['hours'] << 11) | ($timearray['분'] << 5) | ($timearray['초'] >> 1);
  92. }// 'unix2DosTime()' 메서드 끝
  93. /**
  94. * 아카이브에 "파일" 추가
  95. *
  96. * @param 문자열 파일 내용
  97. * @param 문자열 아카이브에 있는 파일 이름(경로를 포함할 수 있음)
  98. * @param 정수 현재 타임스탬프
  99. *
  100. * @access public
  101. */
  102. function addFile($data, $name, $time = 0)
  103. {
  104. $name = str_replace('', '/', $name);
  105. $dtime = decex($this->unix2DosTime($time));
  106. $hexdtime = 'x' . $dtime[6] . $dtime[7]
  107. . '엑스' . $dtime[4] . $dtime[5]
  108. . '엑스' . $dtime[2] . $dtime[3]
  109. . '엑스' . $dtime[0] . $dtime[1];
  110. eval('$hexdtime = "' . $hexdtime . '";');
  111. $fr = "x50x4bx03x04";
  112. $fr .= "x14x00" ; //
  113. 을 추출하는 데 필요한 버전 $fr .= "x00x00"; // 생성 목적 비트 플래그
  114. $fr .= "x08x00"; // 압축 방법
  115. $fr .= $hexdtime; // 마지막 수정 시간 및 날짜
  116. // "로컬 파일 헤더" 세그먼트
  117. $unc_len = strlen($data);
  118. $crc = crc32($data);
  119. $zdata = gzcompress($data);
  120. $c_len = strlen($zdata);
  121. $zdata = substr(substr($zdata, 0, strlen($zdata) - 4), 2); // crc 버그 수정
  122. $fr .= pack('V', $crc); // crc32
  123. $fr .= pack('V', $c_len); // 압축된 파일 크기
  124. $fr .= pack('V', $unc_len); // 압축되지 않은 파일 크기
  125. $fr .= pack('v', strlen($name)); // 파일 이름 길이
  126. $fr .= pack('v', 0); // 추가 필드 길이
  127. $fr .= $name;
  128. // "파일 데이터" 세그먼트
  129. $fr .= $zdata;
  130. // "데이터 설명자" 세그먼트(선택 사항이지만 아카이브가
  131. // 파일로 제공되지 않는 경우 필요함)
  132. $fr .= pack('V', $crc); // crc32
  133. $fr .= pack('V', $c_len); // 압축된 파일 크기
  134. $fr .= pack('V', $unc_len); // 압축되지 않은 파일 크기
  135. // 이 항목을 배열에 추가
  136. $this -> datasec[] = $fr;
  137. $new_offset = strlen(implode('', $this->datasec));
  138. // 이제 중앙 디렉터리 레코드에 추가
  139. $cdrec = " x50x4bx01x02";
  140. $cdrec .= "x00x00"; // 버전은
  141. $cdrec .= "x14x00"; // 추출에 필요한 버전
  142. $cdrec .= "x00x00"; // 생성 목적 비트 플래그
  143. $cdrec .= "x08x00"; // 압축 방법
  144. $cdrec .= $hexdtime; // 마지막 수정 시간 및 날짜
  145. $cdrec .= pack('V', $crc); // crc32
  146. $cdrec .= pack('V', $c_len); // 압축된 파일 크기
  147. $cdrec .= pack('V', $unc_len); // 압축되지 않은 파일 크기
  148. $cdrec .= pack('v', strlen($name) ); // 파일 이름 길이
  149. $cdrec .= pack('v', 0 ); // 추가 필드 길이
  150. $cdrec .= pack('v', 0 ); // 파일 주석 길이
  151. $cdrec .= pack('v', 0 ); // 디스크 번호 start
  152. $cdrec .= pack('v', 0 ); // 내부 파일 속성
  153. $cdrec .= pack('V', 32 ); // 외부 파일 속성 - '아카이브' 비트 세트
  154. $cdrec .= pack('V', $this -> old_offset ); // 로컬 헤더의 상대 오프셋
  155. $this -> old_offset = $new_offset;
  156. $cdrec .= $name;
  157. // 선택적 추가 필드, 파일 주석이 여기에 표시됩니다.
  158. // 중앙 디렉터리에 저장
  159. $this -> ; ctrl_dir[] = $cdrec;
  160. } // 'addFile()' 메서드 끝
  161. /**
  162. * 파일 덤프
  163. *
  164. * @return 압축된 파일 문자열
  165. *
  166. * @access public
  167. */
  168. 함수 파일()
  169. {
  170. $data = implode('', $this -> datasec);
  171. $ctrldir = implode('', $this -> ctrl_dir);
  172. return
  173. $data .
  174. $ctrldir .
  175. $this -> eof_ctrl_dir .
  176. pack('v', sizeof($this -> ctrl_dir)) . // "이 디스크에 있는" 항목의 총 개수
  177. pack('v', sizeof($this -> ctrl_dir)) . // 전체 항목의 총 개수
  178. pack('V', strlen($ctrldir)) . // 중앙 dir
  179. 의 크기 pack('V', strlen($data)) . // 중앙 디렉터리의 시작 위치에 대한 오프셋
  180. "x00x00"; // .zip 파일 주석 길이
  181. } // 'file()' 메서드 끝
  182. }// 'PHPZip' 클래스 종료
  183. ?>
  184. //사용 방법
  185. $z = new PHPZip() // 새로운 생성 A zip 클래스
  186. 방법 1:
  187. $z -> Zip("", "out1.zip") //현재 디렉터리와 하위 디렉터리의 모든 파일 추가
  188. 방법 2:
  189. $files=array('1.txt','gb.txt');
  190. $files[]='5.txt';
  191. $z -> Zip ($files, "out2.zip"); //파일 목록 추가
  192. 방법 3:
  193. $z -> out3 .zip"); //지정된 디렉터리 추가
  194. ?>
코드 복사

PHPZip


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.