Cet article présente principalement des informations pertinentes sur l'interprétation du traitement des fichiers téléchargés en PHP. Il est très bon et a une valeur de référence. Les amis dans le besoin peuvent s'y référer
Nous modifions nos propres informations dans le navigateur, vous rencontrerez des téléchargements d'avatars ; dans la bibliothèque, nous téléchargerons des documents... Le mot « télécharger » existe partout.
PHP est le meilleur langage (programmeurs dans d'autres langages, ne me frappez pas...). PHP présente des avantages naturels dans la gestion des interactions et dispose naturellement de fonctions puissantes pour gérer les fichiers téléchargés.
Tout comme la soumission de données générales, le téléchargement de fichiers nécessite également un formulaire. Créons un formulaire spécial pour télécharger des fichiers.
<form enctype="multipart/form-data" action="upload_file.php" name="upload_form" method="post"> <!--MAX_FILE_SIZE必须在所有的input之前,以后要是想用上传表单,可以在form之后就写隐藏的input--> <input type="hidden" name="MAX_FILE_SIZE" value=""/> 上传的文件: <input type="file" name="userfile"/> <input type="submit" name="sub_button" value="上传文件的提交按钮"/> </form>
OK, analysons cet extrait de code.
L'enctype ci-dessus spécifie le format d'encodage utilisé lorsque les données sont envoyées au serveur. Il a trois valeurs :
Le champ caché MAX_FILE_SIZE (l'unité est en octets) doit être placé avant le champ de saisie du fichier, et sa valeur est la taille maximale du fichier. Ceci est une suggestion pour les navigateurs, PHP vérifiera également cela. Cependant, cette barrière peut être contournée du côté du navigateur, alors ne vous attendez pas à l'utiliser pour bloquer des fichiers volumineux. Cependant, la valeur maximale du fichier est limitée par post_max_size= (number) M dans php.ini . Mais il est préférable d'ajouter cet élément, ce qui peut éviter aux utilisateurs de passer du temps à attendre pour télécharger des fichiers volumineux et de constater que le téléchargement de fichiers volumineux a échoué.
Une fois que l'utilisateur a soumis le formulaire de fichier, le serveur peut accepter les données. Il existe une variable globale $_FILES en PHP pour traiter les fichiers. On suppose que le nom du champ de téléchargement est userfile (peut être modifié à volonté dans le champ).
$_FILES['userfile']['name'] Le nom original du fichier client.
$_FILES['userfile']['type'] Le type MIME du fichier Ceci n'est pas vérifié côté PHP, donc cette valeur n'existe peut-être pas encore.
$_FILES['userfile']['size'] La taille du fichier téléchargé (en octets).
$_FILES['userfile']['tmp_name'] Le nom de fichier temporaire stocké côté serveur après le téléchargement du fichier.
$_FILES['userfile']['error'] Le code d'erreur lié au téléchargement du fichier. Si le téléchargement réussit, la valeur est 0.
Une fois le fichier téléchargé, il est stocké par défaut dans le répertoire temporaire par défaut du serveur et upload_tmp_dir dans php.ini est défini sur un autre chemin.
Ici, nous devons parler d'une fonction move_uploaded_file() :
Cette fonction vérifie et garantit que le fichier spécifié par file est un fichier téléchargé légal ( c'est-à-dire téléchargé via le mécanisme de téléchargement HTTP POST de PHP). Si le fichier est légal, il est déplacé vers le fichier spécifié par newloc.
Si le fichier n'est pas un fichier téléchargé légal, aucune opération ne se produira et move_uploaded_file() renverra false.
Si le fichier est un fichier téléchargé légitime mais ne peut pas être déplacé pour une raison quelconque, aucune action ne se produira et move_uploaded_file() renverra false et un avertissement sera émis.
Cette vérification est particulièrement importante si le fichier téléchargé peut provoquer l'affichage de son contenu à l'utilisateur ou à d'autres utilisateurs de ce système.
Ce qui suit est un exemple de fichier de téléchargement php :
<b>上传文件处理</b> <?php if (isset($_FILES['userfile'])) { $uploaddir = 'upload/'; $uploadfile = $uploaddir . basename($_FILES['userfile']['name']); echo '<pre class="brush:php;toolbar:false">'; if (move_uploaded_file($_FILES['userfile']['tmp_name'], $uploadfile)) { echo '上传文件成功'.'<br>'; } else { echo '上传文件失败'.'<br>'; } echo '这是上传文件的一些信息:' . '<br>'; print_r($_FILES); echo '<pre class="brush:php;toolbar:false">'; die(); } ?> <b>上传表单</b> <!--表单中的enctype属,必须和以下定义保持一致--> <form enctype="multipart/form-data" action="upload_file.php" name="upload_form" method="post"> <!--MAX_FILE_SIZE必须在所有的input之前,以后要是想用上传表单,可以在form之后就写隐藏的input--> <input type="hidden" name="MAX_FILE_SIZE" value=""/> 上传的文件: <input type="file" name="userfile"/> <hr/> <input type="submit" name="sub_button" value="上传文件的提交按钮"/> </form>
Résumé : Ce qui précède représente l'intégralité du contenu de cet article, j'espère qu'il peut être utile pour aider l'apprentissage de chacun.
Recommandations associées :
phpMéthodes pour télécharger divers fichiers en fonction de la fonction d'en-tête
PHP implémente la création et méthode de compression d'image
phpExemple de partage d'un seul fichier et de téléchargements multiples de fichiers
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!