Heim > Backend-Entwicklung > PHP-Tutorial > Zusammenfassung der Probleme beim Hochladen von PHP-Dateien

Zusammenfassung der Probleme beim Hochladen von PHP-Dateien

伊谢尔伦
Freigeben: 2023-03-11 16:12:01
Original
1030 Leute haben es durchsucht

Lassen Sie uns einige der Probleme zusammenfassen, die beim Hochladen von Dateien in PHP häufig auftreten. Sie müssen nicht danach suchen, wenn Sie sie in Zukunft verwenden.

1. Erstellen Sie zuerst die einfachste Upload-Datei

 <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>
Nach dem Login kopieren
<?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";
  }
?>
Nach dem Login kopieren

2. Verstehen Sie dann die superglobalen Variablen $_FILES Values

$_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;]
Nach dem Login kopieren

Darunter alle Werte von $_FILES['userfile']['error']:

UPLOAD_ERR_OK, dessen Wert 0 ist, kein Fehler aufgetreten, Datei hochgeladen erfolgreich.

UPLOAD_ERR_INI_SIZE Der Wert ist 1 und die hochgeladene Datei überschreitet den durch die Option upload_max_filesize in php.ini begrenzten Wert.

UPLOAD_ERR_FORM_SIZE Bei einem Wert von 2 überschreitet die Größe der hochgeladenen Datei den durch die Option MAX_FILE_SIZE im HTML-Formular angegebenen Wert.

UPLOAD_ERR_PARTIAL Der Wert ist 3, die Datei wird nur teilweise hochgeladen.

UPLOAD_ERR_NO_FILE Der Wert ist 4, es wurde keine Datei hochgeladen.

UPLOAD_ERR_NO_TMP_DIR hat einen Wert von 6 und der temporäre Ordner kann nicht gefunden werden. Eingeführt in PHP 4.3.10 und PHP 5.0.3.

UPLOAD_ERR_CANT_WRITE Der Wert ist 7, das Schreiben der Datei ist fehlgeschlagen. Eingeführt in PHP 5.1.0.

3. Viele Situationen: Der Typ der hochgeladenen Datei muss streng beurteilt werden

Wir wissen, dass die Verwendung von $_FILES['userfile']['type'] zu Beurteilen Sie den Typ der hochgeladenen Datei. Dies ist ein sehr unkluger Ansatz, da die Beurteilung auf dem Suffix der Datei basiert. Jeder kann das Suffix einer MP3-Datei in JPG ändern und sie daher offiziell als Bild hochladen empfiehlt die Verwendung der PHP-Erweiterung php_fileinfoUm die Mime-Datei der Datei zu ermitteln, gibt es viele Möglichkeiten, die Erweiterung auf Baidu zu aktivieren, die sich zwischen Win und Linux geringfügig unterscheiden.

4. Szenario 1: Automatisches Umbenennen nach dem Hochladen einer Datei mit demselben Namen

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"]);   
}
Nach dem Login kopieren

5. Szenario 2: Hochladen von Dateien in Verzeichnisse basierend auf Datum

$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"]);
Nach dem Login kopieren

6. Szenario 3: Mehrere Dateien hochladen

<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>
Nach dem Login kopieren
 <?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");
     }
 }
 ?>
Nach dem Login kopieren

In einigen Fällen ist die variable Struktur mehrerer Dateien nicht gut. Verwendung:

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"
        }
    }
}
Nach dem Login kopieren

In vielen Fällen benötigen wir eine Struktur wie diese

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"
        }
}
}
Nach dem Login kopieren

Die Verwendung der folgenden Funktion kann die Struktur leicht konvertieren

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"]);
Nach dem Login kopieren

7 . Manchmal: Mussden Server konfigurierenDie maximale Upload-Dateigröße ändern

Zuerst im Formular


kann die Größe der Upload-Datei begrenzen (kann umgangen werden).

Dann müssen Sie auch die Konfiguration auf dem Server anpassen

php.ini:

max_execution_time = 30 Die maximale Zeit für die Ausführung jedes Skripts in Sekunden
max_input_time = 60. Die Zeit, die jedes Skript verbrauchen kann, die Einheit ist ebenfalls Sekunden
memory_limit = 128M, dies ist der maximale Speicher, der vom ausgeführten Skript verbraucht wird
post_max_size = 8M, die maximale Datenmenge für die Formularübermittlung beträgt 8M, Dieses Element begrenzt nicht das Hochladen einer einzelnen Datei. Die Größe ist auf die übermittelten Daten des gesamten Formulars beschränkt.
upload_max_filesize = 2M, die maximal zulässige Größe hochgeladener Dateien

nginx:

location / {
     root   html;
     index  index.html index.htm;
     client_max_body_size    1000m;
  }
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonZusammenfassung der Probleme beim Hochladen von PHP-Dateien. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage