ホームページ > バックエンド開発 > PHPチュートリアル > PHP を使用して ZIP ファイルを安全かつ効率的に抽出するにはどうすればよいですか?

PHP を使用して ZIP ファイルを安全かつ効率的に抽出するにはどうすればよいですか?

Linda Hamilton
リリース: 2024-12-03 21:56:11
オリジナル
636 人が閲覧しました

How Can I Safely and Efficiently Extract ZIP Files Using PHP?

PHP を使用した ZIP ファイルの抽出

PHP を使用してファイルを解凍しようとすると、URL を介してファイル名を渡すときに問題が発生する可能性がありますコードに見られるように:

<?php
$master = $_GET["master"];
system('unzip $master.zip'); // Incorrect syntax
?>
ログイン後にコピー

構文

主な問題は、system() 呼び出しの構文にあります。正しい構文は、次のようにシステム コマンドを呼び出すことです。

system("unzip $master.zip");
ログイン後にコピー

組み込み PHP 関数の使用

system() 関数はタスクを実行できますが、一般的には推奨されません。 PHP には、ZipArchive などの圧縮ファイルを処理するための組み込み拡張機能が用意されています。以下は ZipArchive の使用例です。

<?php
$zip = new ZipArchive;
$res = $zip->open('file.zip');
if ($res === TRUE) {
  $zip->extractTo('/myzips/extract_path/');
  $zip->close();
  echo 'Extraction successful!';
} else {
  echo 'Extraction failed: ' . $zip->getStatusString();
}
?>
ログイン後にコピー

追加の考慮事項

  • $HTTP_GET_VARS の代わりに $_GET スーパーグローバルを使用します。
  • ユーザーをサニタイズします。潜在的なセキュリティを防ぐために URL パラメーターを介して渡される入力

現在のディレクトリに抽出するためのソリューション

ZIP ファイルをそれが存在するディレクトリと同じディレクトリに抽出するには、ファイルへの絶対パスを決定できます。ファイルを抽出し、それを抽出ターゲットとして指定します:

<?php
$file = 'file.zip';
$path = pathinfo(realpath($file), PATHINFO_DIRNAME);

$zip = new ZipArchive;
$res = $zip->open($file);
if ($res === TRUE) {
  $zip->extractTo($path);
  $zip->close();
  echo "Extraction complete!";
} else {
  echo "Extraction failed: " . $zip->getStatusString();
}
?>
ログイン後にコピー

以上がPHP を使用して ZIP ファイルを安全かつ効率的に抽出するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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