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 rendre votre page de téléchargement plus belle. 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 est similaire au scénario deux, plusieurs fichiers doivent être téléchargés, 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 :
Compétences en matière de téléchargement de fichiers (il existe des fichiers téléchargés uniques en tant que fichiers temporaires côté serveur) Exemple de code :
Traitement de la 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, du 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='{$fileInfo}' type=\"hidden\"/>"; //一定要输出前使用htmlspecialchars, 否则不能正确显示页面值和获取至正确的文件信息 $this->ajaxReturn(array('status' => 1, 'info' => "上传成功", 'version' => $version, 'item' => $item, 'apkName' => $apkName, 'apkInfoHtml' => $apkInfoHtml, 'fileInfo' => $fileInfoHtml)); }
3 En combinant les deux parties du code, nous avons déjà les informations correctes. sur la page. Il vous suffit de ne pas soumettre le fichier au serveur lors de la soumission du formulaire à la fin. Lors du traitement côté serveur, il vous suffit de déplacer le fichier temporaire téléchargé auparavant, et le tour est joué !
$('.upload-file-real').attr('disabled', 'disabled'); //提交表单前,禁用上传文件
4. Travail de suivi
Après avoir téléchargé le fichier temporaire sur le serveur, il n'y a aucun moyen de juger si l'utilisateur annule l'opération en cours. En cas d'annulation, le fichier temporaire. existera 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 !
Merci d'avoir lu, j'espère que cela pourra vous aider, merci pour votre soutien à ce site !
Pour plus d'articles sur les conseils pratiques et les méthodes de traitement back-end du téléchargement de fichiers PHP, veuillez faire attention au site Web PHP chinois !