この PHP クラスは、ファイルを 1 つずつ配列に追加し、最後に追加されたファイルを zip にパッケージ化できます
- /* $Id: zip.lib.php,v 1.1 2004/02/14 15:21:18 anoncvs_tusedb Exp $ */
- // vim: Expandtab sw=4 ts=4 sts=4:
-
-
- /**
- * ZIP ファイル作成クラス。
- * ZIP ファイルを作成します。
- *
- * 最終変更と拡張作成者:
- *
- * Hasin Hayder
- * ホームページ : www.hasinme.info
- * 電子メール : countdraculla@gmail.com
- * IDE : PHP Designer 2005
- *
- *
- * 元のベース:
- *
- * http://www.zend.com/codex.php?id=535&single=1
- * By Eric Mueller
- *
- * http://www.zend.com/codex.php?id=470&single=1
- * by Denis125
- *
- * Peter Listiak 最終更新日
- * 圧縮ファイルの日時
- *
- * 公式 ZIP ファイル形式: http://www.pkware.com/appnote.txt
- *
- * @access public
- */
- class zipfile
- {
- /**
- * 圧縮データを格納する配列
- *
- * @public array $datasec
- */
- public $datasec = array();
-
- /**
- * 中央ディレクトリ
- *
- * @public array $ctrl_dir
- */
- public $ctrl_dir = array() ;
-
- /**
- * 中央ディレクトリレコードの終わり
- *
- * @public string $eof_ctrl_dir
- */
- public $eof_ctrl_dir = "x50x4bx05x06x00x00x00x00";
-
- /**
- * 最終オフセット位置
- *
- * @public integer $old_offset
- */
- public $old_offset = 0;
-
-
- /**
- * Unix タイムスタンプを 4 バイトの DOS 日付と時刻形式に変換します (日付
- * 上位 2 バイト、時刻を下位 2 バイトで大小比較が可能)。
- *
- * @param integer 現在の Unix タイムスタンプ
- *
- * @現在の日付を整数で 4 バイトの DOS 形式で返します
- *
- * @access private
- */
- 関数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['分'] = 0;
- $timearray['秒'] = 0;
- } // end if
-
- return (($timearray['年'] - 1980) << 25) | ($timearray['mon'] << 21) | ($timearray['mday'] << 16) |
- ($timearray['hours'] << 11) | ($timearray['分'] << 5) | ($timearray['秒'] >> 1);
- }// 'unix2DosTime()' メソッドの終わり
-
-
- /**
- * アーカイブに「ファイル」を追加します
- *
- * @param string ファイルの内容
- * @param アーカイブ内のファイルの文字列名 (パスが含まれる場合があります)
- * @param integer 現在のタイムスタンプ
- *
- * @access public
- */
- function addFile($data, $name, $time = 0)
- {
- $name = str_replace('\', ' /', $name);
-
- $dtime = dechex($this->unix2DosTime($time));
- $hexdtime = 'x' 。 $dtime[6] 。 $dtime[7]
- . 'バツ' 。 $dtime[4] 。 $dtime[5]
- . 'バツ' 。 $dtime[2] 。 $dtime[3]
- . 'バツ' 。 $dtime[0] 。 $dtime[1];
- eval('$hexdtime = "' . $hexdtime . '";');
-
- $fr = "x50x4bx03x04";
- $fr .= "x14x00"; // 抽出するにはverが必要です
- $fr .= "x00x00"; // 生成目的ビットフラグ
- $fr .= "x08x00"; // 圧縮方法
- $fr .= $hexdtime; // 最終更新日時
-
- // 「ローカル ファイル ヘッダー」セグメント
- $unc_len = strlen($data);
- $crc = crc32($data);
- $zdata = gzcompress($data);
- $zdata = substr(substr($zdata, 0, strlen($zdata) - 4), 2); // crc バグを修正します
- $c_len = strlen($zdata);
- $fr .= Pack('V', $crc); // crc32
- $fr .= Pack('V', $c_len); // 圧縮ファイルサイズ
- $fr .= Pack('V', $unc_len); // 非圧縮ファイルサイズ
- $fr .= Pack('v', strlen($name)); // ファイル名の長さ
- $fr .= Pack('v', 0); // 余分なフィールド長
- $fr .= $name;
-
- // "ファイルデータ" セグメント
- $fr .= $zdata;
-
- // "データ記述子" セグメント (オプションですが、アーカイブではない場合は必須です
- //ファイルとして機能します)
- $fr .= Pack('V', $crc); // crc32
- $fr .= Pack('V', $c_len); // 圧縮ファイルサイズ
- $fr .= Pack('V', $unc_len); // 非圧縮ファイルサイズ
-
- // このエントリを配列に追加します
- $this -> datasec[] = $fr;
-
- // 中央ディレクトリにレコードを追加します
- $cdrec = "x50x4bx01x02";
- $cdrec .= "x00x00"; //
- が作成したバージョン $cdrec .= "x14x00"; // 抽出に必要なバージョン
- $cdrec .= "x00x00"; // 生成目的ビットフラグ
- $cdrec .= "x08x00"; // 圧縮方法
- $cdrec .= $hexdtime; // 最終更新日時
- $cdrec .= Pack('V', $crc); // crc32
- $cdrec .= Pack('V', $c_len); // 圧縮ファイルサイズ
- $cdrec .= Pack('V', $unc_len); // 非圧縮ファイルサイズ
- $cdrec .= Pack('v', strlen($name) ); // ファイル名の長さ
- $cdrec .= Pack('v', 0 ); // 余分なフィールド長
- $cdrec .= Pack('v', 0 ); // ファイルコメントの長さ
- $cdrec .= Pack('v', 0 ); // ディスク番号 start
- $cdrec .= Pack('v', 0 ); // 内部ファイル属性
- $cdrec .= Pack('V', 32 ); // 外部ファイル属性 - 'archive' ビット セット
-
- $cdrec .= Pack('V', $this -> old_offset ); // ローカルヘッダーの相対オフセット
- $this -> old_offset += strlen($fr);
-
- $cdrec .= $name;
-
- // オプションの追加フィールド、ファイルコメントがここに入ります
- // 中央ディレクトリに保存します
- $this -> ctrl_dir[] = $cdrec;
- } // 'addFile()' メソッドの終わり
-
-
- /**
- * ファイルをダンプします
- *
- * @return string 圧縮ファイル
- *
- * @access public
- */
- 関数 file()
- {
- $data = implode('', $this - > datasec);
- $ctrldir = implode('', $this -> ctrl_dir);
-
- return
- $data .
- $ctrldir .
- $this -> eof_ctrl_dir .
- Pack('v', sizeof($this -> ctrl_dir)) 。 // 「このディスク上」のエントリの合計数
- Pack('v', sizeof($this -> ctrl_dir)) 。 // 全体のエントリの合計数
- Pack('V', strlen($ctrldir)) 。 // 中央の dir
- Pack('V', strlen($data)) のサイズ。 // 中央ディレクトリの先頭へのオフセット
- "x00x00"; // .zip ファイルのコメントの長さ
- }// 'file()' メソッドの終わり
-
-
- /**
- * オリジナルの addFile 関数のラッパー
- *
- * 1 月 29 日、午前 1 時 29 分に Hasin Hayder によって作成されました
- *
- * @param array Zip ファイルに追加される相対/絶対パスを持つファイルの配列
- *
- * @アクセス公開
- */
- function addFiles($files /*Only Pass Array*/)
- {
- foreach($files as $file)
- {
- if (is_file($file)) //ディレクトリチェック
- {
- $data = implode("",file($file));
- $this->addFile($data,$file);
- }
- }
- }
-
- /**
- * オリジナルファイル関数のラッパー
- *
- * 1月29日午前1時29分にHasin Hayderによって作成されました
- *
- * @param string 出力ファイル名
- *
- * @access public
- */
- 関数出力($file)
- {
- $fp=fopen($file,"w");
- fwrite($fp,$this->file());
- fclose($fp);
- }
-
-
-
- } // 'zipfile' クラスの終わり
复制代
|