爱收集资源网

PHP变量、数组技巧与正则表达式、模板使用

网络 2023-06-28 19:03

上一篇:PHP的变量和字段应用方法是哪些,正则表达式和模板如何用下一篇:PHP中提升执行效率的简单方法有什么

本篇内容介绍了“PHP实现文件上传的前后端处理有没有哪些方法”的有关知识,在实际项目的操作过程或是学习过程中,不少人就会碰到这样的问题,接出来就让小编带你们学习一下怎样处理这种情况吧!希望你们仔细阅读,才能学有所成!

引语:在上一篇文章中说到,在页面中可以用隐藏的方法让你的上传页面看上去漂亮。并且这对于性能来说,并没有哪些卵用,这么在后台的处理中,莫非就没有一些处理方法么?所谓后台的方法,应当要包括上传得快一点,上传的文件大一点!这么,本文就来聊聊,前端处理都有些哪些方法吧!

vue加laravel前后分离_文件上传 前后端分离_文件上传上传与下载

业务场景一、我们只会选择一个单个的文件上传,但是不须要做一些即时的验证工作。这么,其实并没有哪些优化可言了,由于,最后你要做的,只是将这个文件置于表单里最后一起递交,直接处理即可!

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

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

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

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

1.页面js处理

文件上传上传与下载_vue加laravel前后分离_文件上传 前后端分离

//点击选择完成文件后,触发上传文件操作,将文件上传至服务器临时目录 $('.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 = ""; //一定要输出前使用htmlspecialchars, 否则不能正确显示页面值和获取至正确的文件信息 $this->ajaxReturn(array('status' => 1, 'info' => "上传成功", 'version' => $version, 'item' => $item, 'apkName' => $apkName, 'apkInfoHtml' => $apkInfoHtml, 'fileInfo' => $fileInfoHtml));
    }

vue加laravel前后分离_文件上传上传与下载_文件上传 前后端分离

3.通过以两部份代码的配合,我们在页面上早已有正确的信息了,只须要在最后递交表单的时侯,不要将文件递交到服务器,在服务器端处理时,只需将之前上传的临时文件联通一下位置即可,这样即使大功告成了!

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

4.后续工作

文件上传上传与下载_文件上传 前后端分离_vue加laravel前后分离

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

5.正题

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

上传文件到服务器临时目录,前端处理原理看上去很简单,而且也须要你仔细调试,起码当年我在做这个小功能时,着实费了不少劲才缕清楚的!

到此这篇关于“PHP实现文件上传的前后端处理有没有哪些方法”的文章就介绍到这了,更多相关PHP实现文件上传的前后端处理有没有哪些方法内容,欢迎关注群英网路技术资讯频道,小编将为你们输出更多高质量的实用文章!

文件上传 前后端分离
上一篇:团结拼搏,创佳绩! 下一篇:没有了