


Wie Thinkphp5 die Upload-Funktion von Bildern, Audio- und Videodateien implementiert
In der folgenden thinkphpFramework-Tutorial-Kolumne erfahren Sie, wie Thinkphp5 die Upload-Funktion von Bildern, Audio- und Videodateien implementiert. Ich hoffe, dass es für Freunde in Not hilfreich ist!
Die erste ist der synchrone Upload, die einfachste Upload-Methode, die darin besteht, nach dem Klicken auf das Absenden des Formulars zu springen.
Der folgende Front-End-Code
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>上传文件</title> </head> <body> <form action="upload" enctype="multipart/form-data" method="post"> <input type="file" name="image" /> <br> <input type="submit" value="上传" /> </form> </body> </html>
Beachten Sie, dass der enctypemussenctype="multipart/form-data"
und die Lösung gepostet werden muss.
Für den Back-End-Code nehmen Sie einfach den Beispielcode der offiziellen tp5-Website:
public function upload(){ // 获取表单上传文件 例如上传了001.jpg $file = request()->file('image'); // 移动到框架应用根目录/public/uploads/ 目录下 if($file){ $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads'); if($info){ // 成功上传后 获取上传信息 // 输出 jpg echo $info->getExtension(); // 输出 20160820/42a79759f284b767dfcb2a0197904287.jpg echo $info->getSaveName(); // 输出 42a79759f284b767dfcb2a0197904287.jpg echo $info->getFilename(); }else{ // 上传失败获取错误信息 echo $file->getError(); } }; }
Später stellte ich fest, dass das, was ich tat, sehr einfach war, also verbesserte ich den Front-End-Code und implementierte den Dateityp im Front-End-Code Bei der Überprüfung wurde die Synchronisierung auf asynchrone Ajax-Übermittlung umgestellt und gleichzeitig auf formdata umgestellt, um Dateidaten zu übermitteln. Der Link zum Übermitteln der Datei wird zurückgegeben, während die Front-End-Vorschau nur eine Vorschau der Bilder anzeigen kann . Der geänderte Front-End-Code lautet
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>上传文件</title> </head> <body> <form action="uploads1a" id="myform"> <input type="file" name="image" id="file" /> </form> <p id="test"></p> <button id="btn">点击上传</button> <p> <img src="" id="see"> </p> <script type="text/javascript"> var btn = document.getElementById("btn"); var file=document.getElementById("file"); var promise=["png","jpg","jpeg","gif","mp3","mp4","svg"]; file.onchange=function(){ var name=file.value; var ext=name.substring(name.lastIndexOf(".") + 1).toLowerCase(); var res=promise.indexOf(ext); if (res<0) { alert("文件格式不正确"); document.getElementById("btn").disabled=true; }else{ document.getElementById("btn").disabled=false; } } btn.onclick = function() { var val=document.getElementById("file").value; if (val.length==0) { return; } var fromData = new FormData(document.forms[0]); fromData.append("test", "formdata"); var oAjax = new XMLHttpRequest(); oAjax.open('post', "uploadAjax", true); oAjax.send(fromData); oAjax.onreadystatechange = function() { if (oAjax.readyState == 4) { if (oAjax.status >= 200 && oAjax.status < 300 || oAjax.status == 304) { console.log(oAjax.responseText); var data=JSON.parse(oAjax.responseText); document.getElementById("see").setAttribute("src","/thinkphp"+data.src); document.getElementById("file").value=""; } else { console.log(oAjax.status); } } }; } </script> </body> </html>
Der Back-End-Code wurde verbessert
public function uploadAjax(){ // 获取表单上传文件 例如上传了001.jpg $file = request()->file('image'); $test=request()->post("test"); $src=[];//返回文件路径 // 移动到框架应用根目录/public/uploads/ 目录下 if($file){ $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads'); if($info){ // 成功上传后 获取上传信息 // 输出 jpg $info->getExtension(); // 输出 20160820/42a79759f284b767dfcb2a0197904287.jpg $info->getSaveName(); // 输出 42a79759f284b767dfcb2a0197904287.jpg $info->getFilename(); $src["src"]=DS.'public'.DS.'uploads'.DS.$info->getSaveName(); }else{ // 上传失败获取错误信息 $file->getError(); } }; return json_encode($src); }
Details, z. B. werden die Fehlerrückgabeinformationen nach dem Hochladen nicht verarbeitet.
Die Gesamtimplementierung ist wie folgt: Dies selbst bietet noch viel Raum für Verbesserungen, z. B. das Löschen der hochgeladenen Datei oder die Überprüfung, ob die Datei erneut hochgeladen oder gelöscht werden kann die zuvor hochgeladene Datei. Wenn der Dateiname nicht verarbeitet und der Originalname hochgeladen wird, wird die Originaldatei nach dem Hochladen natürlich überschrieben.
Verwandte Empfehlungen: Die neuesten 10 Thinkphp-Video-Tutorials
Das obige ist der detaillierte Inhalt vonWie Thinkphp5 die Upload-Funktion von Bildern, Audio- und Videodateien implementiert. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Lösung für den bei der Bereitstellung von thinkphp5 in Pagoda gemeldeten Fehler: 1. Öffnen Sie den Pagoda-Server, installieren Sie die PHP-Pathinfo-Erweiterung und aktivieren Sie sie. 2. Konfigurieren Sie die Datei „.access“ mit dem Inhalt „RewriteRule ^(.*)$ index.php ?s=/$1 [QSA ,PT,L]“; 3. Aktivieren Sie in der Website-Verwaltung einfach die Pseudostatik von thinkphp.

Lösung dafür, dass das Umschreiben von thinkphp5-URLs nicht funktioniert: 1. Überprüfen Sie, ob das Modul mod_rewrite.so in der Konfigurationsdatei httpd.conf geladen ist. 2. Ändern Sie None in AllowOverride None in All. 3. Ändern Sie die Apache-Konfigurationsdatei .htaccess in „RewriteRule ^“. (.*)$ index.php [L,E=PATH_INFO:$1]“ und speichern Sie es.

Methoden für thinkphp5 zum Abrufen der angeforderten URL: 1. Verwenden Sie die Methode „$request = Request::instance();“ der Klasse „\think\Request“, um die aktuellen URL-Informationen abzurufen Funktion „$request->url()“, um die vollständige URL-Adresse einschließlich des Domainnamens zu erhalten.

thinkphp5-Beitrag kann keinen Wert abrufen, da TP5 die strpos-Funktion verwendet, um den app/json-String im Inhaltstypwert des Headers zu finden. Die Lösung besteht darin, den Inhaltstypwert des Headers auf app/json zu setzen.

So entfernen Sie das thinkphp5-Titelleistensymbol: 1. Suchen Sie die Datei favicon.ico unter dem öffentlichen thinkphp5-Framework. 2. Löschen Sie die Datei oder wählen Sie ein anderes Bild aus, um sie in favicon.ico umzubenennen und die ursprüngliche Datei favicon.ico zu ersetzen.

Lösung für die Meldung thinkphp5, dass der Controller nicht existiert: 1. Überprüfen Sie, ob der Namespace im entsprechenden Controller korrekt geschrieben ist, und ändern Sie ihn in den richtigen Namespace. 2. Öffnen Sie die entsprechende tp-Datei und ändern Sie den Klassennamen.

So fragen Sie die Daten von gestern in ThinkPHP5 ab: 1. Öffnen Sie ThinkPHP5-bezogene Dateien. 2. Fragen Sie die Daten von gestern über den Ausdruck „db('table')->whereTime('c_time', 'yesterday')->select();“ ab .

So legen Sie Fehleraufforderungen in thinkphp5 fest: 1. Geben Sie den öffentlichen Ordner im Projektstammverzeichnis ein und öffnen Sie die Eintragsdatei index.php. 2. Sehen Sie sich die Kommentare zum Debug-Modus-Schalter an. 3. Passen Sie den Wert der Konstante „APP_DEBUG“ an auf „true“ setzen, um eine Fehlermeldung anzuzeigen.
