PHP 文件上传后端处理实用技巧方法

发布时间 - 2026-01-10 22:21:11    点击率:

PHP 文件上传后端处理实用技巧方法

引语:在上一篇文章中说到,在页面中可以用隐藏的方式让你的上传页面看起来漂亮。但是这对于性能来说,并没有什么卵用,那么在后台的处理中,难道就没有一些处理技巧么?所谓后台的技巧,应该要包括上传得快一点,上传的文件大一点!那么,本文就来说说,后端处理都有些什么技巧吧!

业务场景一、我们只会选择一个单个的文件上传,而且不需要做一些即时的验证工作。那么,也许并没有什么优化可言了,因为,最后你要做的,只是将这个文件放在表单里最后一起提交,直接处理即可!

业务场景二、需要上传多个文件,而且需要时时验证文件内部内容,并时行相应页面显示。对于这种况,在用户选择了上传文件之后,我们需要立即将文件上传,因为我们需要读取文件里的信息,在最后提交的时候,我们也需要提交一次文件。很明显,在这里是存在一个重复上传的工作的,一个耗费用户时间,二个是耗费服务器带宽资源!优化,能够想得到的方法也很简单,能不能在第一次上传完文件之后,就将文件保留在服务器,真正提交表单的时候,去读取这个已经被上传的临时文件即可。是的,这就是我们的处理思路!

业务场景三、与场景二类似,需要上传多个文件,但是多个文件可能是分开上传的。即我们可能第一次上传了10M,第二次上传了10M,总共上传了10次,那么,在服务器端来说的话,一次性提交肯定是超出了上传大小的限制了,但是如果,我们是分每一次的上传,这是可以的,而最后提交的时候,我们只需要将简短的文本信息传上去即可!

思路的确是简单的,看起来,也是没什么问题,但是,也许我是能力有限,当时着实花了我不少时间去处理这个什么鬼!下面,我将给出一些示例代码,以供参考:

文件上传技巧(将单次上传的文件作为临时文件存在在服务器端)示例代码:

1. 页面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. 很明显,页面里面需要获取文件信息,后台处理代码(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. 通过以两部分代码的配合,我们在页面上已经有正确的信息了,只需要在最后提交表单的时候, 不要将文件提交到服务器,在服务器端处理时,只需将之前上传的临时文件移动一下位置即可 ,这样就算大功告成了!

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

4. 后续工作

将临时文件上传到服务器后,是没办法判断用户是否取消当前操作的,如果取消了,则临时文件将一直存在于服务器,所以,我们需要一个定时清理临时目录的脚本。当然,这个很简单,就只需要找到这个目录,比较一下时间,比如超过一天前的文件就给删除。注意控制清理频率即可!

5. 题外话

日志真的很重要,哪里出错了,哪里删除文件了,哪里清理数据库了,一定要做好记录,否则,到时查找原因时,到哪里去喊救命!

上传文件到服务器临时目录,后端处理原理看起来很简单,但是也需要你仔细调试,至少当初我在做这个小功能时,着实费了不少劲才缕清楚的!

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# PHP  # 文件上传后端处理  # 文件上传后端处理小技巧  # 文件上传  # 后端处理方法  # php文件怎么打开 如何执行php文件  # PHPExcel读取Excel文件的实现代码  # PHP中读写文件实现代码  # PHP文件上传实例详解!!!  # jQuery Ajax文件上传(php)  # php 下载保存文件保存到本地的两种实现方法  # PHP获取文件绝对路径的代码(上一级目录)  # PHP 上传文件大小限制  # PHP 图片文件上传实现代码  # PHP获取当前文件所在目录 getcwd()函数  # php读取目录及子目录下所有文件名的方法  # php利用header函数实现文件下载时直接提示保存  # PHP 配置文件中open_basedir选项作用  # 一个经典的PHP文件上传类分享  # 上传  # 上传文件  # 表单  # 多个  # 只需  # 临时文件  # 有什么  # 传了  # 后端  # 要做  # 很简单  # 至正  # 要将  # 很明显  # 这是  # 我是  # 都有  # 在这里  # 我在 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南  音响网站制作视频教程,隆霸音响官方网站?  Laravel Fortify是什么,和Jetstream有什么关系  Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  Android自定义控件实现温度旋转按钮效果  手机网站制作与建设方案,手机网站如何建设?  千库网官网入口推荐 千库网设计创意平台入口  Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】  Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权  Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  如何在不使用负向后查找的情况下匹配特定条件前的换行符  昵图网官方站入口 昵图网素材图库官网入口  laravel怎么实现图片的压缩和裁剪_laravel图片压缩与裁剪方法  Laravel怎么定时执行任务_Laravel任务调度器Schedule配置与Cron设置【教程】  ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法  Laravel怎么为数据库表字段添加索引以优化查询  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  深圳网站制作培训,深圳哪些招聘网站比较好?  Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程  Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门  消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  如何在VPS电脑上快速搭建网站?  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  原生JS获取元素集合的子元素宽度实例  如何快速完成中国万网建站详细流程?  如何在建站主机中优化服务器配置?  Python函数文档自动校验_规范解析【教程】  Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置  JS碰撞运动实现方法详解  Laravel如何自定义错误页面(404, 500)?(代码示例)  JS中页面与页面之间超链接跳转中文乱码问题的解决办法  在线教育网站制作平台,山西立德教育官网?  如何快速配置高效服务器建站软件?  Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能  如何确保西部建站助手FTP传输的安全性?  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  java获取注册ip实例  Laravel Eloquent:优雅地将关联模型字段扁平化到主模型中  百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏  如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?  Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】  Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  如何在 React 中条件性地遍历数组并渲染元素  node.js报错:Cannot find module &#39;ejs&#39;的解决办法  Laravel怎么实现支付功能_Laravel集成支付宝微信支付