Problem: Das Hochladen von Dateien über eine jQuery-AJAX-Anfrage schlägt fehl, obwohl der Browser „[object FormData]“ und eine Fehlermeldung anzeigt Leeren Sie den Ordner „Uploads“ auf dem Server.
Lösung: Zum Erfolg Um Dateien mit jQuery AJAX hochzuladen, ist ein serverseitiges Skript erforderlich, um die hochgeladene Datei zu verarbeiten und an den gewünschten Speicherort zu verschieben.
Das folgende aktualisierte jQuery-Skript verweist auf einen Server -seitiges PHP-Skript namens „upload.php“:
$("#upload").on("click", function() { var file_data = $("#sortpicture").prop("files")[0]; var form_data = new FormData(); form_data.append("file", file_data); $.ajax({ url: 'upload.php', dataType: 'text', cache: false, contentType: false, processData: false, data: form_data, type: 'post', success: function(php_script_response){ alert(php_script_response); } }); });
Das Folgende Das Skript „upload.php“ prüft die hochgeladene Datei auf Fehler und verschiebt sie in das Verzeichnis „uploads“:
<?php if (0 < $_FILES['file']['error']) { echo 'Error: ' . $_FILES['file']['error'] . '<br>'; } else { move_uploaded_file($_FILES['file']['tmp_name'], 'uploads/' . $_FILES['file']['name']); } ?>
Um die Datei auf dem Server mit PHP umzubenennen:
move_uploaded_file($_FILES['file']['tmp_name'], 'uploads/my_new_filename.whatever');
Das obige ist der detaillierte Inhalt vonWarum schlägt das Hochladen meiner jQuery-AJAX-Datei nach PHP fehl, obwohl „[object FormData]' angezeigt wird?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!