Maison >développement back-end >tutoriel php >Conseils pratiques et méthodes pour implémenter le traitement back-end de téléchargement de fichiers en PHP

Conseils pratiques et méthodes pour implémenter le traitement back-end de téléchargement de fichiers en PHP

墨辰丷
墨辰丷original
2018-05-26 16:40:061904parcourir

Cet article présente principalement des informations pertinentes sur les compétences pratiques et les méthodes de traitement back-end des téléchargements de fichiers PHP. Voici une explication détaillée du traitement back-end et un exemple de code simple. Les amis dans le besoin peuvent s'y référer

.

Conseils pratiques et méthodes pour le traitement back-end du téléchargement de fichiers PHP

Citation : Comme mentionné dans l'article précédent, vous pouvez utiliser des méthodes cachées dans la page pour donner à votre page de téléchargement un aspect beau. Mais cela ne sert à rien en termes de performances, alors n'y a-t-il pas des techniques de traitement dans le traitement en arrière-plan ? Les soi-disant compétences de base devraient inclure le téléchargement plus rapide et le téléchargement de fichiers plus volumineux ! Ainsi, cet article parlera des compétences disponibles en matière de traitement back-end !

Scénario commercial 1. Nous ne sélectionnerons qu'un seul fichier à télécharger, et il n'est pas nécessaire d'effectuer un travail de vérification immédiat. Ensuite, peut-être qu'il n'y a pas d'optimisation du tout, car au final, il suffit de mettre ce fichier dans le formulaire et de le soumettre ensemble, puis de le traiter directement !

Scénario commercial 2. Plusieurs fichiers doivent être téléchargés et le contenu interne des fichiers doit être vérifié de temps en temps et affiché sur la page correspondante. Dans ce cas, une fois que l'utilisateur a choisi de télécharger le fichier, nous devons télécharger le fichier immédiatement, car nous devons lire les informations contenues dans le fichier, et lors de la soumission à la fin, nous devons également soumettre le fichier une fois. Évidemment, il y a ici une tâche de téléchargement répétitive. L'une consomme du temps utilisateur et l'autre consomme des ressources de bande passante du serveur ! Optimisation, la méthode envisageable est également très simple : après le premier téléchargement du fichier, le fichier peut-il être conservé sur le serveur, et lorsque le formulaire est effectivement soumis, il suffit de lire le fichier temporaire téléchargé. Oui, c'est notre approche !

Le scénario commercial trois , similaire au scénario deux, nécessite le téléchargement de plusieurs fichiers, mais plusieurs fichiers peuvent être téléchargés séparément. Autrement dit, nous avons peut-être téléchargé 10 millions pour la première fois, 10 millions pour la deuxième fois et téléchargé 10 fois au total. Ensuite, côté serveur, la soumission unique doit avoir dépassé la limite de taille de téléchargement, mais si c'est le cas. Il est possible de télécharger à chaque fois, et lors de la soumission, il suffit de télécharger un court message texte !

L'idée est en effet simple, et il semble qu'il n'y ait pas de problème. Cependant, peut-être que mes capacités sont limitées, et il m'a vraiment fallu beaucoup de temps pour y parvenir ! Ci-dessous, je vais donner un exemple de code pour référence :

Technique de téléchargement de fichiers (il existe un seul fichier téléchargé en tant que fichier temporaire côté serveur) Exemple de code :

1. Page js

 //点击选择完成文件后,触发上传文件操作,将文件上传至服务器临时目录
  $('.upload-real-file').off().on('change', function(){
   if(!$(this).val()){
    return false;
   }
   var responseObjId = $(this).attr('response-id');
   var responseObj = $('#' + responseObjId);
   $('#Form').ajaxSubmit({
    url:'/aa/bb/uploadTmpApkTool',
    resetForm: false,
    dataType: 'json',
    beforeSubmit: function(option){
     window.loading = layer.load(2);
    },
    success: function(data, statusText){
     layer.close(window.loading);
     if(data.status == 1){
      responseObj.html(data.apkInfoHtml);
      var parentContainer = responseObj.parent().parent(),
       nameContainer = parentContainer.find('.file-name-container');
      nameContainer.html(data.apkName);
      nameContainer.attr('title', data.apkName);
      responseObj.find('.file-tmp').html(data.fileInfo); //将文件信息存放于隐藏域中,以便在提交时能找到 
      $(submitId).removeAttr('disabled');
     }else{
      layer.alert(data.info);
     }
    },
    error: function(data){
     layer.close(window.loading);
     layer.alert('未知错误,请稍后再试!');
    }
   });
   return false;//防止dialog 自动关闭
  });

2. Évidemment, la page doit obtenir des informations sur le fichier et le code de traitement en arrière-plan (PHP)

  $apkConfig = $this->_getApkConfig();
  $params = $this->getFilteredParam('get');
  $subFile = $_FILES['apkToolFiles'];
  $apkName = $apkInfoHtml = "";
  if(empty($subFile))
  {
   $this->ajaxReturn(array('status' => -4, 'info' => '请选择要上传的文件'));
  }

  foreach ($subFile['name'] as $subKey => $subVal)
  {
   if ($subFile['name'][$subKey])
   {
    $fileData = $this->_getFileData($subFile, $subKey);
    $checkData = array(
     'maxSize' => $apkConfig['FILE_MAX_SIZE'],
     'savePath' => $apkConfig['TMP_CHILD_PATH'],
     'extArr' => array('apk'),
     'releaseName' => str_replace('.apk', '', $fileData['fileName']), //特有
    );
    $checkResult = $this->_checkFileData($fileData, $checkData);
    if ($checkResult['status'] != 1)
    {
     $this->ajaxReturn($checkResult);
    }
    //移动文件
    $filePath = $checkData['savePath'] . '/' . $fileData['fileName'] . '.tmp' . genRandStr(6);;
    $this->_moveUploadedFile($fileData['tmpName'], $filePath);
    $apkInfo = $this->_apkParser($filePath); //解析
    if($apkInfo['UMENG_CHANNEL'] != 'UMENG_CHANNEL_VALUE')
    {
     @unlink($filePath);        //删除无效文件
     $this->ajaxReturn(array('status' => 0, 'info' => "UMENG_CHANNEL的值要是 UMENG_CHANNEL_VALUE才行"));
    }
    $tmpFileArr['file_info'] = array(
     'name' => $subFile['name'][$subKey],
     'type' => $subFile['type'][$subKey],
     'tmp_name' => str_replace($apkConfig['TMP_CHILD_PATH'] . '/', '', $filePath),
     'error' => $subFile['error'][$subKey],
     'size' => $subFile['size'][$subKey],
    );    //转存该值,不再重复上传文件
   }
   else
   {
    $this->ajaxReturn(array('status' => 0, 'info' => "文件不能为空"));
   }
   foreach ($apkInfo as $key => $val)
   {
    $apkInfoHtml .= "{$key}:{$val} \r\n";
   }
   $apkName = $fileData['fileName'];
   $version = $apkInfo['versionName'];
  }
  $fileInfo = htmlspecialchars(json_encode($tmpFileArr['file_info']));
  $fileInfoHtml = "<input name=\"apkToolFileTmp[]\" value=&#39;{$fileInfo}&#39; type=\"hidden\"/>"; //一定要输出前使用htmlspecialchars, 否则不能正确显示页面值和获取至正确的文件信息

  $this->ajaxReturn(array(&#39;status&#39; => 1, &#39;info&#39; => "上传成功", &#39;version&#39; => $version, &#39;item&#39; => $item, &#39;apkName&#39; => $apkName, &#39;apkInfoHtml&#39; => $apkInfoHtml, &#39;fileInfo&#39; => $fileInfoHtml));
 }

3. En combinant les deux parties de code, nous avons déjà les informations correctes sur la page, et il nous suffit de les soumettre au end Lors de la création du formulaire, ne soumettez pas le fichier au serveur Lors du traitement côté serveur, déplacez simplement le fichier temporaire téléchargé auparavant, et le tour est joué !

$(&#39;.upload-file-real&#39;).attr(&#39;disabled&#39;, &#39;disabled&#39;);  //提交表单前,禁用上传文件

4. Travaux de suivi

Après avoir téléchargé le fichier temporaire sur le serveur, il n'y a aucun moyen de juger si le L'utilisateur a annulé l'opération en cours. En cas d'annulation, les fichiers temporaires existeront toujours sur le serveur, nous avons donc besoin d'un script pour nettoyer régulièrement le répertoire temporaire. Bien sûr, c'est très simple. Il vous suffit de trouver ce répertoire et de comparer l'heure. Par exemple, les fichiers datant de plus d'un jour seront supprimés. Faites juste attention à contrôler la fréquence de nettoyage !

5. Digression

Les journaux sont vraiment importants. Là où quelque chose s'est mal passé, où les fichiers ont été supprimés et où la base de données a été nettoyée, vous devez bien l'enregistrer. raisons, Où appeler à l'aide !

Télécharger des fichiers dans le répertoire temporaire du serveur. Le principe du traitement back-end semble très simple, mais il nécessite également de le déboguer soigneusement. Au moins lorsque je faisais cette petite fonction, cela prenait beaucoup de temps. d'efforts pour le comprendre !

Ce qui précède représente l’intégralité du contenu de cet article, j’espère qu’il sera utile à l’étude de chacun.


Recommandations associées :

Mise en œuvre de PHPBackendExplication détaillée des exemples de paiement et de remboursement UnionPay

L'implémentation simultanée de la fonction curl en PHP réduit le backendtemps d'accès

Après que le framework PHP appelle Java Terminal , résolvez le problème selon lequel les paramètres ne peuvent pas être transmis

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