国产精品成人VA在线观看,亚洲日韩在线中文字幕综合,亚洲AV电影天堂男人的天堂,久久人人爽人人爽人人av东京热

News新聞

業(yè)界新聞動(dòng)態(tài)、技術(shù)前沿
Who are we?

您的位置:首頁(yè)      樂道系統(tǒng)FAQ      PHP 文件上傳后端處理實(shí)用技巧方法

PHP 文件上傳后端處理實(shí)用技巧方法

標(biāo)簽: 發(fā)布日期:2017-01-06 00:00:00 284

PHP 文件上傳后端處理實(shí)用技巧方法

引語:在上一篇文章中說到,在頁(yè)面中可以用隱藏的方式讓你的上傳頁(yè)面看起來漂亮。但是這對(duì)于性能來說,并沒有什么卵用,那么在后臺(tái)的處理中,難道就沒有一些處理技巧么?所謂后臺(tái)的技巧,應(yīng)該要包括上傳得快一點(diǎn),上傳的文件大一點(diǎn)!那么,本文就來說說,后端處理都有些什么技巧吧!

業(yè)務(wù)場(chǎng)景一、我們只會(huì)選擇一個(gè)單個(gè)的文件上傳,而且不需要做一些即時(shí)的驗(yàn)證工作。那么,也許并沒有什么優(yōu)化可言了,因?yàn)?,最后你要做的,只是將這個(gè)文件放在表單里最后一起提交,直接處理即可!

業(yè)務(wù)場(chǎng)景二、需要上傳多個(gè)文件,而且需要時(shí)時(shí)驗(yàn)證文件內(nèi)部?jī)?nèi)容,并時(shí)行相應(yīng)頁(yè)面顯示。對(duì)于這種況,在用戶選擇了上傳文件之后,我們需要立即將文件上傳,因?yàn)槲覀冃枰x取文件里的信息,在最后提交的時(shí)候,我們也需要提交一次文件。很明顯,在這里是存在一個(gè)重復(fù)上傳的工作的,一個(gè)耗費(fèi)用戶時(shí)間,二個(gè)是耗費(fèi)服務(wù)器帶寬資源!優(yōu)化,能夠想得到的方法也很簡(jiǎn)單,能不能在第一次上傳完文件之后,就將文件保留在服務(wù)器,真正提交表單的時(shí)候,去讀取這個(gè)已經(jīng)被上傳的臨時(shí)文件即可。是的,這就是我們的處理思路!

業(yè)務(wù)場(chǎng)景三、與場(chǎng)景二類似,需要上傳多個(gè)文件,但是多個(gè)文件可能是分開上傳的。即我們可能第一次上傳了10M,第二次上傳了10M,總共上傳了10次,那么,在服務(wù)器端來說的話,一次性提交肯定是超出了上傳大小的限制了,但是如果,我們是分每一次的上傳,這是可以的,而最后提交的時(shí)候,我們只需要將簡(jiǎn)短的文本信息傳上去即可!

思路的確是簡(jiǎn)單的,看起來,也是沒什么問題,但是,也許我是能力有限,當(dāng)時(shí)著實(shí)花了我不少時(shí)間去處理這個(gè)什么鬼!下面,我將給出一些示例代碼,以供參考:

文件上傳技巧(將單次上傳的文件作為臨時(shí)文件存在在服務(wù)器端)示例代碼:

1. 頁(yè)面js處理

 //點(diǎn)擊選擇完成文件后,觸發(fā)上傳文件操作,將文件上傳至服務(wù)器臨時(shí)目錄
  $('.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); //將文件信息存放于隱藏域中,以便在提交時(shí)能找到 
      $(submitId).removeAttr('disabled');
     }else{
      layer.alert(data.info);
     }
    },
    error: function(data){
     layer.close(window.loading);
     layer.alert('未知錯(cuò)誤,請(qǐng)稍后再試!');
    }
   });
   return false;//防止dialog 自動(dòng)關(guān)閉
  });