ホームページ > バックエンド開発 > PHPチュートリアル > ファイルのセットを zip にパッケージ化する php クラス

ファイルのセットを zip にパッケージ化する php クラス

WBOY
リリース: 2016-07-25 08:43:06
オリジナル
864 人が閲覧しました

この PHP クラスは、ファイルを 1 つずつ配列に追加し、最後に追加されたファイルを zip にパッケージ化できます

  1. /* $Id: zip.lib.php,v 1.1 2004/02/14 15:21:18 anoncvs_tusedb Exp $ */
  2. // vim: Expandtab sw=4 ts=4 sts=4:
  3. /**
  4. * ZIP ファイル作成クラス。
  5. * ZIP ファイルを作成します。
  6. *
  7. * 最終変更と拡張作成者:
  8. *
  9. * Hasin Hayder
  10. * ホームページ : www.hasinme.info
  11. * 電子メール : countdraculla@gmail.com
  12. * IDE : PHP Designer 2005
  13. *
  14. *
  15. * 元のベース:
  16. *
  17. * http://www.zend.com/codex.php?id=535&single=1
  18. * By Eric Mueller
  19. *
  20. * http://www.zend.com/codex.php?id=470&single=1
  21. * by Denis125
  22. *
  23. * Peter Listiak 最終更新日
  24. * 圧縮ファイルの日時
  25. *
  26. * 公式 ZIP ファイル形式: http://www.pkware.com/appnote.txt
  27. *
  28. * @access public
  29. */
  30. class zipfile
  31. {
  32. /**
  33. * 圧縮データを格納する配列
  34. *
  35. * @public array $datasec
  36. */
  37. public $datasec = array();
  38. /**
  39. * 中央ディレクトリ
  40. *
  41. * @public array $ctrl_dir
  42. */
  43. public $ctrl_dir = array() ;
  44. /**
  45. * 中央ディレクトリレコードの終わり
  46. *
  47. * @public string $eof_ctrl_dir
  48. */
  49. public $eof_ctrl_dir = "x50x4bx05x06x00x00x00x00";
  50. /**
  51. * 最終オフセット位置
  52. *
  53. * @public integer $old_offset
  54. */
  55. public $old_offset = 0;
  56. /**
  57. * Unix タイムスタンプを 4 バイトの DOS 日付と時刻形式に変換します (日付
  58. * 上位 2 バイト、時刻を下位 2 バイトで大小比較が可能)。
  59. *
  60. * @param integer 現在の Unix タイムスタンプ
  61. *
  62. * @現在の日付を整数で 4 バイトの DOS 形式で返します
  63. *
  64. * @access private
  65. */
  66. 関数unix2DosTime($unixtime = 0) {
  67. $timearray = ($unixtime == 0) ? getdate() : getdate($unixtime);
  68. if ($timearray['year'] < 1980) {
  69. $timearray['year'] = 1980;
  70. $timearray['mon'] = 1;
  71. $ timearray['mday'] = 1;
  72. $timearray['hours'] = 0;
  73. $timearray['分'] = 0;
  74. $timearray['秒'] = 0;
  75. } // end if
  76. return (($timearray['年'] - 1980) << 25) | ($timearray['mon'] << 21) | ($timearray['mday'] << 16) |
  77. ($timearray['hours'] << 11) | ($timearray['分'] << 5) | ($timearray['秒'] >> 1);
  78. }// 'unix2DosTime()' メソッドの終わり
  79. /**
  80. * アーカイブに「ファイル」を追加します
  81. *
  82. * @param string ファイルの内容
  83. * @param アーカイブ内のファイルの文字列名 (パスが含まれる場合があります)
  84. * @param integer 現在のタイムスタンプ
  85. *
  86. * @access public
  87. */
  88. function addFile($data, $name, $time = 0)
  89. {
  90. $name = str_replace('\', ' /', $name);
  91. $dtime = dechex($this->unix2DosTime($time));
  92. $hexdtime = 'x' 。 $dtime[6] 。 $dtime[7]
  93. . 'バツ' 。 $dtime[4] 。 $dtime[5]
  94. . 'バツ' 。 $dtime[2] 。 $dtime[3]
  95. . 'バツ' 。 $dtime[0] 。 $dtime[1];
  96. eval('$hexdtime = "' . $hexdtime . '";');
  97. $fr = "x50x4bx03x04";
  98. $fr .= "x14x00"; // 抽出するにはverが必要です
  99. $fr .= "x00x00"; // 生成目的ビットフラグ
  100. $fr .= "x08x00"; // 圧縮方法
  101. $fr .= $hexdtime; // 最終更新日時
  102. // 「ローカル ファイル ヘッダー」セグメント
  103. $unc_len = strlen($data);
  104. $crc = crc32($data);
  105. $zdata = gzcompress($data);
  106. $zdata = substr(substr($zdata, 0, strlen($zdata) - 4), 2); // crc バグを修正します
  107. $c_len = strlen($zdata);
  108. $fr .= Pack('V', $crc); // crc32
  109. $fr .= Pack('V', $c_len); // 圧縮ファイルサイズ
  110. $fr .= Pack('V', $unc_len); // 非圧縮ファイルサイズ
  111. $fr .= Pack('v', strlen($name)); // ファイル名の長さ
  112. $fr .= Pack('v', 0); // 余分なフィールド長
  113. $fr .= $name;
  114. // "ファイルデータ" セグメント
  115. $fr .= $zdata;
  116. // "データ記述子" セグメント (オプションですが、アーカイブではない場合は必須です
  117. //ファイルとして機能します)
  118. $fr .= Pack('V', $crc); // crc32
  119. $fr .= Pack('V', $c_len); // 圧縮ファイルサイズ
  120. $fr .= Pack('V', $unc_len); // 非圧縮ファイルサイズ
  121. // このエントリを配列に追加します
  122. $this -> datasec[] = $fr;
  123. // 中央ディレクトリにレコードを追加します
  124. $cdrec = "x50x4bx01x02";
  125. $cdrec .= "x00x00"; //
  126. が作成したバージョン $cdrec .= "x14x00"; // 抽出に必要なバージョン
  127. $cdrec .= "x00x00"; // 生成目的ビットフラグ
  128. $cdrec .= "x08x00"; // 圧縮方法
  129. $cdrec .= $hexdtime; // 最終更新日時
  130. $cdrec .= Pack('V', $crc); // crc32
  131. $cdrec .= Pack('V', $c_len); // 圧縮ファイルサイズ
  132. $cdrec .= Pack('V', $unc_len); // 非圧縮ファイルサイズ
  133. $cdrec .= Pack('v', strlen($name) ); // ファイル名の長さ
  134. $cdrec .= Pack('v', 0 ); // 余分なフィールド長
  135. $cdrec .= Pack('v', 0 ); // ファイルコメントの長さ
  136. $cdrec .= Pack('v', 0 ); // ディスク番号 start
  137. $cdrec .= Pack('v', 0 ); // 内部ファイル属性
  138. $cdrec .= Pack('V', 32 ); // 外部ファイル属性 - 'archive' ビット セット
  139. $cdrec .= Pack('V', $this -> old_offset ); // ローカルヘッダーの相対オフセット
  140. $this -> old_offset += strlen($fr);
  141. $cdrec .= $name;
  142. // オプションの追加フィールド、ファイルコメントがここに入ります
  143. // 中央ディレクトリに保存します
  144. $this -> ctrl_dir[] = $cdrec;
  145. } // 'addFile()' メソッドの終わり
  146. /**
  147. * ファイルをダンプします
  148. *
  149. * @return string 圧縮ファイル
  150. *
  151. * @access public
  152. */
  153. 関数 file()
  154. {
  155. $data = implode('', $this - > datasec);
  156. $ctrldir = implode('', $this -> ctrl_dir);
  157. return
  158. $data .
  159. $ctrldir .
  160. $this -> eof_ctrl_dir .
  161. Pack('v', sizeof($this -> ctrl_dir)) 。 // 「このディスク上」のエントリの合計数
  162. Pack('v', sizeof($this -> ctrl_dir)) 。 // 全体のエントリの合計数
  163. Pack('V', strlen($ctrldir)) 。 // 中央の dir
  164. Pack('V', strlen($data)) のサイズ。 // 中央ディレクトリの先頭へのオフセット
  165. "x00x00"; // .zip ファイルのコメントの長さ
  166. }// 'file()' メソッドの終わり
  167. /**
  168. * オリジナルの addFile 関数のラッパー
  169. *
  170. * 1 月 29 日、午前 1 時 29 分に Hasin Hayder によって作成されました
  171. *
  172. * @param array Zip ファイルに追加される相対/絶対パスを持つファイルの配列
  173. *
  174. * @アクセス公開
  175. */
  176. function addFiles($files /*Only Pass Array*/)
  177. {
  178. foreach($files as $file)
  179. {
  180. if (is_file($file)) //ディレクトリチェック
  181. {
  182. $data = implode("",file($file));
  183. $this->addFile($data,$file);
  184. }
  185. }
  186. }
  187. /**
  188. * オリジナルファイル関数のラッパー
  189. *
  190. * 1月29日午前1時29分にHasin Hayderによって作成されました
  191. *
  192. * @param string 出力ファイル名
  193. *
  194. * @access public
  195. */
  196. 関数出力($file)
  197. {
  198. $fp=fopen($file,"w");
  199. fwrite($fp,$this->file());
  200. fclose($fp);
  201. }
  202. } // 'zipfile' クラスの終わり
复制代

php、zip


ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート