Problème : Le téléchargement de fichiers via la requête jQuery AJAX échoue malgré l'affichage par le navigateur de "[object FormData]" et d'un dossier "uploads" vide sur le serveur.
Solution : Pour réussir à télécharger des fichiers à l'aide de jQuery AJAX, un script côté serveur est nécessaire pour gérer le fichier téléchargé et le déplacer vers l'emplacement souhaité.
Le script jQuery mis à jour suivant pointe vers un script PHP côté serveur appelé "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); } }); });
Le script "upload.php" suivant vérifie les erreurs dans le fichier téléchargé et le déplace vers le répertoire "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']); } ?>
Pour renommer le fichier fichier sur le serveur en utilisant PHP :
move_uploaded_file($_FILES['file']['tmp_name'], 'uploads/my_new_filename.whatever');
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!