PHPファイルのアップロードに関する問題の概要

伊谢尔伦
リリース: 2023-03-11 16:12:01
オリジナル
1002 人が閲覧しました

PHP でファイルをアップロードするときによく発生する問題のいくつかをまとめて、将来ファイルを使用するときに探す必要がないようにしましょう。

1. まず最も単純なアップロードファイルを作成します

 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
 </head>
 <body>
 <form action="upload_file.php" method="post"
 enctype="multipart/form-data">
 <label for="file">Filename:</label>
 <input type="file" name="file" id="file" /> 
 <br />
 <input type="submit" name="submit" value="Submit" />
 </form>
 </body>
 </html>
ログイン後にコピー
<?php
if (($_FILES["file"]["size"] < 20000)
  {
  if ($_FILES["file"]["error"] > 0)
    {
    echo "Return Code: " . $_FILES["file"]["error"] . "<br />";
    } 
  else
    {
    echo "Upload: " . $_FILES["file"]["name"] . "<br />";
    echo "Type: " . $_FILES["file"]["type"] . "<br />";
    echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";
    echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />";
    if (
file_exists
("upload/" . $_FILES["file"]["name"]))
      {
      echo $_FILES["file"]["name"] . " already exists. ";
      }
    else
      {
      move_uploaded_file($_FILES["file"]["tmp_name"],
      "upload/" . $_FILES["file"]["name"]);
      echo "Stored in: " . "upload/" . $_FILES["file"]["name"];
      }
    }
  }
else
  {
  echo "Invalid file";
  }
?>
ログイン後にコピー

2. 次に、スーパーグローバル変数$_FILES

$_FILES[&#39;userfile&#39;][&#39;name&#39;]
$_FILES[&#39;userfile&#39;][&#39;type&#39;]
$_FILES[&#39;userfile&#39;][&#39;size&#39;]
$_FILES[&#39;userfile&#39;][&#39;tmp_name&#39;]
$_FILES[&#39;userfile&#39;][&#39;error&#39;]
ログイン後にコピー

の値を理解します。このうち、$_FILES['userfile']['error'] ] 値:

UPLOAD_ERR_OK 値は 0 で、エラーは発生せず、ファイルのアップロードは成功します。

UPLOAD_ERR_INI_SIZE 値は 1 で、アップロードされたファイルは php.ini の Upload_max_filesize オプションで制限された値を超えています。

UPLOAD_ERR_FORM_SIZE 値は 2 で、アップロードされたファイルのサイズが HTML フォームの MAX_FILE_SIZE オプションで指定された値を超えています。

UPLOAD_ERR_PARTIAL その値は 3 で、ファイルは部分的にのみアップロードされます。

UPLOAD_ERR_NO_FILE その値は 4 で、ファイルはアップロードされませんでした。

UPLOAD_ERR_NO_TMP_DIR の値は 6 で、一時フォルダーが見つかりません。 PHP 4.3.10 および PHP 5.0.3 で導入されました。

UPLOAD_ERR_CANT_WRITE 値は 7 で、ファイルの書き込みに失敗しました。 PHP 5.1.0で導入されました。

3. 多くの状況: アップロードされたファイルの種類を厳密に判断する必要があります

アップロードされたファイルの種類を判断するために $_FILES['userfile']['type'] を使用するのは非常に賢明ではないアプローチであることはわかっています。 , 判断はファイルに基づいているため、誰でもmp3ファイルの拡張子をjpgに変更して画像に偽装してアップロードできるため、PHPはファイルのMIMEを決定するためにPHP拡張子php_fileinfoを使用することを公式に推奨しています。 Baidu で拡張機能を有効にする方法は数多くありますが、Win と Linux では若干異なります。

4. シナリオ 1: 同じ名前のファイルをアップロードした後に自動的に名前を変更する

if (file_exists("./upload/" . $_FILES["file"]["name"]))  
{    
   do{  
       $suffix ="";  
       $suffix_length = 4;  
       $str = "0123456789abcdefghijklmnopqrstuvwxyz";  
       $len = strlen($str)-1; 
       //文件名后追加4个随机字符  
       for($i=0 ; $i<$suffix_length; $i++){  
          $suffix .= $str[rand(0,$len)];  
       }  
       $upload_filename = $_FILES[&#39;file&#39;][&#39;name&#39;];                                            
       $filename = substr($upload_filename,0,strrpos($upload_filename,".")).$suffix.".".substr($upload_filename,strrpos($_FILES["file"]["name"],".")+1); 
   }while(file_exists("./upload/".$filename));  
       move_uploaded_file($_FILES["file"]["tmp_name"],"./upload/" . $filename);  
}else{  
       move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]);   
}
ログイン後にコピー

5. シナリオ 2: 日付に基づいてファイルをアップロードする

$structure = &#39;./&#39;.date("Y").&#39;/&#39;.date("m").&#39;/&#39;.date("d").&#39;/&#39;;
if (!mkdir($structure, 0777, true)) {
    die(&#39;Failed to create folders...&#39;);
}
move_uploaded_file($_FILES["file"]["tmp_name"],$structure . $_FILES["file"]["name"]);
ログイン後にコピー

6. シナリオ 3: 複数のファイルをアップロードする

<form action="" method="post" enctype="multipart/form-data">
 <p>Pictures:
 <input type="file" name="pictures[]" />
 <input type="file" name="pictures[]" />
 <input type="file" name="pictures[]" />
 <input type="submit" value="Send" />
 </p>
 </form>
ログイン後にコピー
 <?php
 foreach ($_FILES["pictures"]["error"] as $key => $error) {
     if ($error == UPLOAD_ERR_OK) {
         $tmp_name = $_FILES["pictures"]["tmp_name"][$key];
         $name = $_FILES["pictures"]["name"][$key];
         move_uploaded_file($tmp_name, "data/$name");
     }
 }
 ?>
ログイン後にコピー

はい 複数のファイルの場合、この変数構造は使いにくいです:

array(1) {
    ["upload"]=>array(2) {
        ["name"]=>array(2) {
            [0]=>string(9)"file0.txt"
            [1]=>string(9)"file1.txt"
        }
        ["type"]=>array(2) {
            [0]=>string(10)"text/plain"
            [1]=>string(10)"text/html"
        }
    }
}
ログイン後にコピー

多くの場合、必要なのはこれに似た構造です

array(1) {
    ["upload"]=>array(2) {
        [0]=>array(2) {
            ["name"]=>string(9)"file0.txt"
            ["type"]=>string(10)"text/plain"
        },
        [1]=>array(2) {
            ["name"]=>string(9)"file1.txt"
            ["type"]=>string(10)"text/html"
        }
}
}
ログイン後にコピー

次の関数を使用すると、構造を簡単に変換できます

function perse_array($vector) { 
     $result = array(); 
     foreach($vector as $key1 => $value1) 
         foreach($value1 as $key2 => $value2) 
             $result[$key2][$key1] = $value2; 
     return $result; 
 } 
 $upload = perse_array($_FILES["upload"]);
ログイン後にコピー

7. 場合によっては: サーバーの設定が必要 最大アップロード ファイル サイズを変更する

まず、フォームに

アップロードファイルのサイズを制限できます(バイパス可能)。

その後、サーバーの設定も調整する必要があります

php.ini:

max_execution_time = 30 各スクリプトの最大実行時間(秒単位)

max_input_time = 60、各スクリプトが消費できる時間、単位秒です
memory_limit = 128M、これはスクリプトによって消費される最大メモリです
post_max_size = 8M、フォームによって送信される最大データは8Mです、この項目はアップロードされる単一ファイルのサイズを制限しませんが、送信されるデータを制限しますフォーム全体の。
upload_max_filesize = 2M、アップロードされるファイルの最大許容サイズ

nginx:

location / {
     root   html;
     index  index.html index.htm;
     client_max_body_size    1000m;
  }
ログイン後にコピー

以上がPHPファイルのアップロードに関する問題の概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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