Maison  >  Article  >  développement back-end  >  Deux façons d'implémenter le téléchargement de fichiers en php

Deux façons d'implémenter le téléchargement de fichiers en php

墨辰丷
墨辰丷original
2018-06-04 10:25:112140parcourir

Cet article présente principalement deux façons d'implémenter le téléchargement de fichiers PHP en détail. Les amis intéressés peuvent s'y référer

Il existe généralement deux façons de télécharger des fichiers :

Oui Deux types :
1. Méthode de formulaire de saisie standard, utilisant généralement $_FILES pour recevoir ;
2. Transmission en méthode Base64, généralement un téléchargement asynchrone AJAX.

La première
méthode de formulaire de saisie standard convient au téléchargement de fichiers volumineux et prend en charge les lots. Phrases clés du code html :

<form enctype="multipart/form-data" method="post" action="upload.php"">
  <input type="file" name="id_pic[]" accept="image/*" class="form-control" multiple />
  <input type="submit" value="上传 " />
</form>

Différents noms :

<form enctype="multipart/form-data" method="post" action="upload.php"">
  <input type="file" name="id_pic_1" accept="image/*" class="form-control" />
  <input type="file" name="id_pic_2" accept="image/*" class="form-control" />
  <input type="submit" value="上传 " />
</form>

Parmi eux, enctype="multipart/form-data" est essentiel pour le téléchargement de fichiers. De plus, type="file" définit le type d'entrée et accept="image/*" spécifie la priorité dans le téléchargement des images (manuel de référence MIME). Multiple prend en charge la sélection de plusieurs fichiers à la fois et pic[] reçoit plusieurs fichiers sous la forme d'un tableau. Le terminal mobile peut également ajouter le paramètre capture="camera" pour sélectionner la caméra pour prendre des photos et les télécharger.

Traitement backend :
Obtenez les fichiers téléchargés via $_FILES.

$files = $_FILES;
Lors du transfert de plusieurs fichiers, si les noms sont différents, le format du tableau $_FILES renvoyé est différent.

Quand les noms sont les mêmes :

array(1) {
 ["id_pic"] => array(5) {
  ["name"] => array(2) {
   [0] => string(5) "1.jpg"
   [1] => string(5) "2.jpg"
  }
  ["type"] => array(2) {
   [0] => string(10) "image/jpeg"
   [1] => string(10) "image/jpeg"
  }
  ["tmp_name"] => array(2) {
   [0] => string(27) "C:\Windows\Temp\php7A7E.tmp"
   [1] => string(27) "C:\Windows\Temp\php7A7F.tmp"
  }
  ["error"] => array(2) {
   [0] => int(0)
   [1] => int(0)
  }
  ["size"] => array(2) {
   [0] => int(77357)
   [1] => int(56720)
  }
 }
}

Quand les noms sont différents :

   array(2) {
 ["id_pic_1"] => array(5) {
  ["name"] => string(5) "1.jpg"
  ["type"] => string(10) "image/jpeg"
  ["tmp_name"] => string(27) "C:\Windows\Temp\phpBBEE.tmp"
  ["error"] => int(0)
  ["size"] => int(77357)
 }
 ["id_pic_2"] => array(5) {
  ["name"] => string(5) "2.jpg"
  ["type"] => string(10) "image/jpeg"
  ["tmp_name"] => string(27) "C:\Windows\Temp\phpBBEF.tmp"
  ["error"] => int(0)
  ["size"] => int(56720)
 }
}

Lors de l'exécution d'un parcours foreach sur $_FILES, le format de sortie précédent n'est pas très pratique. Cette dernière peut être parcourue directement. Nous pouvons écrire une méthode de conversion unifiée :

function dealFiles($files) {
    $fileArray = array();
    $n     = 0;
    foreach ($files as $key=>$file){
      if(is_array($file[&#39;name&#39;])) {
        $keys    =  array_keys($file);
        $count   =  count($file[&#39;name&#39;]);
        for ($i=0; $i<$count; $i++) {
          $fileArray[$n][&#39;key&#39;] = $key;
          foreach ($keys as $_key){
            $fileArray[$n][$_key] = $file[$_key][$i];
          }
          $n++;
        }
      }else{
        $fileArray = $files;
        break;
      }
    }
    return $fileArray;
 }

D'accord, nous avons expliqué comment le backend traite le tableau $_FILES reçu et le convertit au format unifié. . Les tâches suivantes sont principalement :
1. Vérifiez si le fichier téléchargé est illégal
2. Vérifiez si le fichier téléchargé dépasse la taille
3.
4. Renommer le fichier ;

Une fonction très importante est utilisée dans le processus de téléchargement : move_uploaded_file(filename, $destination) pour effectuer des opérations de déplacement de fichiers. Déplacez $_FILES['id_pic']['tmp_name'] vers le nouveau chemin. Bien sûr, avant de déplacer, vous pouvez utiliser is_uploaded_file($_FILES['id_pic']['tmp_name']) pour déterminer si le fichier est téléchargé normalement.

Les téléchargements de fichiers multiples utilisent move_uploaded_file() plusieurs fois dans une boucle pour effectuer l'opération de déplacement.

Le deuxième type
concerne principalement le téléchargement de photos.
Utilisez l'événement change de l'entrée pour traiter l'image (comme la compression) avec canevas, puis envoyez le flux de fichiers au backend via ajax.

Le principe de base est de restituer l'image via Canvas, puis de la compresser et de l'enregistrer dans une chaîne base64 via la méthode toDataURL (peut être compilée dans une image au format jpg).

Traitement back-end :
Le back-end finira par recevoir la chaîne base64 envoyée par le front-end, puis traitera la chaîne dans un image. Plus précisément, veuillez utiliser le mot-clé base64 pour le langage de développement d'images pour Google|Baidu. Il y a un base64Len dans le résultat généré par le front-end, qui est la longueur de la chaîne, et le back-end doit vérifier si la soumission est complète.

//php示例:
$img = base64_decode($_POST[&#39;img&#39;]);
$img = imagecreatefromstring($img);

Résumé : Ce qui précède est l'intégralité du contenu de cet article, j'espère qu'il sera utile à l'étude de chacun.

Recommandations associées :

phpComment se connecter à la base de données Oracle et analyse simple

PHP package classe d'opération MSSql et exemple d'analyse complet

phpÉtapes de base et brève analyse de la connexion à la base de données Oracle

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn