Heim > PHP-Framework > Denken Sie an PHP > So implementieren Sie die Datei-Upload-Funktion in ThinkPHP6

So implementieren Sie die Datei-Upload-Funktion in ThinkPHP6

WBOY
Freigeben: 2023-06-20 08:35:13
Original
3862 Leute haben es durchsucht

Mit der kontinuierlichen Entwicklung des Internets müssen immer mehr Websites Funktionen zum Hochladen von Dateien implementieren. In ThinkPHP6 ist es auch sehr einfach, die Datei-Upload-Funktion zu implementieren. Heute stellen wir vor, wie Sie die Datei-Upload-Funktion in ThinkPHP6 implementieren.

1. Datei-Upload-Parameter konfigurieren

Bevor Sie mit der Implementierung der Datei-Upload-Funktion beginnen, müssen Sie zunächst die Datei-Upload-Parameter in der Konfigurationsdatei von ThinkPHP6 festlegen. Suchen Sie die Projektkonfigurationsdatei config/app.php und fügen Sie dann den folgenden Code im Parameter-Array hinzu:

'upload' => [
    'maxSize' => 1024 * 1024 * 10, //文件上传的最大大小
    'exts' => ['jpg', 'gif', 'png', 'jpeg'], //允许上传的文件后缀
    'rootPath' => app()->getRootPath() . 'public/uploads/', //文件上传的根目录
    'savePath' => '', //文件保存的子目录
    'subName' => ['date', 'Ymd'], //子目录名称的命名规则
],
Nach dem Login kopieren

Hier legen wir die maximale Datei-Upload-Größe auf 10 MB fest und die Dateisuffixe, die hochgeladen werden dürfen, sind jpg, gif, png und jpeg. Das Stammverzeichnis für den Datei-Upload ist public/uploads/ und die Benennungsregel für Unterverzeichnisse ist auf die Benennung nach Datum (Jahr, Monat, Tag) festgelegt.

2. Implementieren Sie die Datei-Upload-Funktion

Nachdem Sie die Datei-Upload-Parameter konfiguriert haben, können Sie mit der Implementierung der Datei-Upload-Funktion beginnen. Schreiben Sie den folgenden Code in den Controller:

public function upload()
{
    $file = request()->file('image');
    if ($file) {
        $info = $file->validate(['ext' => 'jpg,png,gif,jpeg'])->move(config('upload.rootPath'));
        if ($info) {
            $data = [
                'code' => 0,
                'msg' => '上传成功',
                'url' => config('upload.rootPath') . $info->getSaveName(),
            ];
        } else {
            $data = [
                'code' => 1,
                'msg' => $file->getError(),
                'url' => '',
            ];
        }
    } else {
        $data = [
            'code' => 1,
            'msg' => '请选择要上传的文件',
            'url' => '',
        ];
    }

    return json($data);
}
Nach dem Login kopieren

Hier erhalten wir zunächst die hochgeladene Datei über die Methode request()->file('image'), um festzustellen, ob die Datei vorhanden ist Überprüfen Sie, ob das vom Benutzer hochgeladene Dateiformat korrekt ist. Verwenden Sie schließlich die Methode move(), um die Datei hochzuladen und das Ergebnis eines erfolgreichen Uploads oder eines fehlgeschlagenen Uploads zurückzugeben.

3. Seitenimplementierung

Abschließend müssen wir die Datei-Upload-Funktion auf der Seite implementieren. Der Code lautet wie folgt:

<form id="upload-form" action="<?php echo url('upload'); ?>" method="post" enctype="multipart/form-data">
    <input type="file" name="image" id="image" accept="image/jpeg,image/png,image/gif">
</form>
<button id="btn-upload" type="button">上传</button>

<script>
$(function() {
    $('#btn-upload').click(function() {
        var formData = new FormData($('#upload-form')[0]);
        $.ajax({
            url: $('#upload-form').attr('action'),
            type: 'post',
            data: formData,
            contentType: false,
            processData: false,
            success: function(res) {
                if (res.code === 0) {
                    alert(res.msg);
                    $('#image').val('');
                } else {
                    alert(res.msg);
                }
            },
            error: function(xhr, status, error) {
                alert('上传错误:' + error);
            }
        });
    });
});
</script>
Nach dem Login kopieren

Hier haben wir der Seite ein Formular und den Namenswert des Eingabe-Tags hinzugefügt Die hochgeladene Datei ist „image“. Verwenden Sie dann die ajax()-Methode von jQuery, um die Formulardaten im FormData-Modus auf den Controller hochzuladen und entsprechende Eingabeaufforderungen bereitzustellen, nachdem der Upload erfolgreich war oder fehlgeschlagen ist.

4. Zusammenfassung

Mit dem obigen Code haben wir die Datei-Upload-Funktion in ThinkPHP6 erfolgreich implementiert. Gleichzeitig müssen wir auch auf die Sicherheit achten, sicherstellen, dass die von Benutzern hochgeladenen Dateien das richtige Format und die richtige Größe haben, verhindern, dass das Hochladen von Dateien dem System schadet, und die Sicherheit der Benutzer und des Systems gewährleisten.

Das obige ist der detaillierte Inhalt vonSo implementieren Sie die Datei-Upload-Funktion in ThinkPHP6. 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