Heim >Backend-Entwicklung >PHP-Tutorial >Sicherheitsleitfaden zum Hochladen von PHP-Dateien: So überprüfen Sie den MIME-Typ hochgeladener Dateien mithilfe des $_FILES-Arrays

Sicherheitsleitfaden zum Hochladen von PHP-Dateien: So überprüfen Sie den MIME-Typ hochgeladener Dateien mithilfe des $_FILES-Arrays

PHPz
PHPzOriginal
2023-07-29 15:02:111881Durchsuche

Sicherheitsleitfaden zum Hochladen von PHP-Dateien: So verwenden Sie das Array $_FILES, um den MIME-Typ hochgeladener Dateien zu überprüfen.

Einführung:
In der Entwicklung ist das Hochladen von Dateien eine sehr häufige Funktion. Allerdings kann eine fehlerhafte Funktion zum Hochladen von Dateien zu Sicherheitsproblemen führen. Böswillige Benutzer können schädliche Dateien hochladen, um Remotecode auszuführen oder an vertrauliche Informationen zu gelangen. Um die Sicherheit der Datei-Upload-Funktion zu gewährleisten, müssen wir die hochgeladenen Dateien korrekt überprüfen und filtern. In diesem Artikel wird erläutert, wie Sie mit dem Array $_FILES den MIME-Typ hochgeladener Dateien überprüfen und so die Sicherheit der Datei-Upload-Funktion erhöhen.

Was sind MIME-Typen? Der Typ
MIME (Multipurpose Internet Mail Extensions) ist ein Standard zur Darstellung von Dateitypen. Es basiert auf der Dateierweiterung und wird verwendet, um den Inhaltstyp der Datei anzugeben. Beim Datei-Upload können wir sicherstellen, dass die hochgeladene Datei dem von uns erwarteten Typ entspricht, indem wir den MIME-Typ der Datei überprüfen, um zu verhindern, dass nicht vertrauenswürdige Dateien auf den Server gelangen.

Verwenden Sie das Array $_FILES, um Informationen zu hochgeladenen Dateien zu erhalten.
Das Array $_FILES in PHP enthält relevante Informationen während des Datei-Upload-Vorgangs. Wir können dieses Array verwenden, um die Eigenschaften der hochgeladenen Datei abzurufen, einschließlich Dateiname, temporärer Dateipfad, Dateigröße usw. Hier ist ein Beispiel:

<form action="upload.php" method="post" enctype="multipart/form-data">
    <input type="file" name="upload_file">
    <input type="submit" value="上传文件">
</form>

<?php
if(isset($_FILES['upload_file'])){
    $file_name = $_FILES['upload_file']['name'];
    $file_tmp = $_FILES['upload_file']['tmp_name'];
    $file_size = $_FILES['upload_file']['size'];
    
    // 其他操作...
}
?>

So überprüfen Sie den MIME-Typ einer hochgeladenen Datei
Durch die Überprüfung des MIME-Typs einer Datei können wir die Sicherheit des Datei-Uploads gewährleisten. PHP bietet eine Möglichkeit, den MIME-Typ einer Datei mithilfe der Funktionen finfo_open() und finfo_file() abzurufen. Das Folgende ist ein Beispielcode zum Überprüfen des MIME-Typs einer Datei:

<?php
if(isset($_FILES['upload_file'])){
    $file_tmp = $_FILES['upload_file']['tmp_name'];
    
    // 创建一个Fileinfo资源
    $finfo = finfo_open(FILEINFO_MIME_TYPE);
    
    // 获取文件的MIME类型
    $mime_type = finfo_file($finfo, $file_tmp);
    
    // 关闭Fileinfo资源
    finfo_close($finfo);
    
    // 其他操作...
}
?>

Im obigen Beispiel erstellen wir zunächst eine Fileinfo-Ressource mit der Funktion finfo_open() und der Parameter FILEINFO_MIME_TYPE wird verwendet, um den MIME-Typ der Datei anzugeben wir müssen bekommen. Anschließend verwenden wir die Funktion finfo_file(), um den MIME-Typ der Datei abzurufen, und die übergebenen Parameter sind die Fileinfo-Ressource und der temporäre Pfad der Datei. Schließlich verwenden wir die Funktion finfo_close(), um die Fileinfo-Ressource zu schließen.

So prüfen Sie, ob der MIME-Typ einer Datei legal ist
Sobald wir den MIME-Typ der hochgeladenen Datei erhalten haben, müssen wir ihn überprüfen, um sicherzustellen, dass er legal ist. Mit der Funktion in_array() können wir prüfen, ob der MIME-Typ in unserer Liste der zulässigen MIME-Typen enthalten ist. Hier ist ein Beispielcode:

$allowed_mime_types = array('image/jpeg', 'image/png', 'image/gif');
if(in_array($mime_type, $allowed_mime_types)){
    // MIME类型合法,进行其他操作...
}else{
    // MIME类型不合法,进行错误处理...
}

Im obigen Beispiel definieren wir ein Array zulässiger MIME-Typen $allowed_mime_types, das die von uns zugelassenen Dateitypen enthält. Dann verwenden wir die Funktion in_array(), um zu prüfen, ob sich $file_mime_type im Array $allowed_mime_types befindet. Wenn der MIME-Typ zulässig ist, können wir andere Vorgänge ausführen. Wenn nicht, können wir eine Fehlerbehandlung durchführen oder das Hochladen der Datei ablehnen.

Zusammenfassung:
Das Hochladen von Dateien ist eine häufige Funktion in der Webentwicklung, eine falsche Funktion zum Hochladen von Dateien kann jedoch zu Sicherheitsrisiken führen. Um die Sicherheit der Datei-Upload-Funktion zu gewährleisten, müssen wir die hochgeladenen Dateien korrekt überprüfen und filtern. In diesem Artikel wird beschrieben, wie Sie mit dem Array $_FILES den MIME-Typ hochgeladener Dateien überprüfen und so die Sicherheit der Datei-Upload-Funktion erhöhen. Durch die Überprüfung und Überprüfung des MIME-Typs von Dateien können wir verhindern, dass nicht vertrauenswürdige Dateien auf den Server gelangen, und so die Sicherheit des Systems verbessern.

Das obige ist der detaillierte Inhalt vonSicherheitsleitfaden zum Hochladen von PHP-Dateien: So überprüfen Sie den MIME-Typ hochgeladener Dateien mithilfe des $_FILES-Arrays. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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