相關(guān)關(guān)鍵詞
關(guān)于我們
最新文章
- PHP中opcode緩存簡(jiǎn)單用法分析
- thinkPHP控制器變量在模板中的顯示方法示例
- PHP move_uploaded_file() 函數(shù)(將上傳的文件移動(dòng)到新位置)
- dirname(__FILE__)的含義和應(yīng)用說明
- thinkPHP5框架實(shí)現(xiàn)分頁(yè)查詢功能的方法示例
- PHP中單雙號(hào)與變量
- PHP獲得當(dāng)日零點(diǎn)時(shí)間戳的方法分析
- Laravel ORM對(duì)Model::find方法進(jìn)行緩存示例詳解
- PHP讀寫文件高并發(fā)處理操作實(shí)例詳解
- 【CLI】利用Curl下載文件實(shí)時(shí)進(jìn)度條顯示的實(shí)現(xiàn)
PHP 文件上傳后端處理實(shí)用技巧方法
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)閉 });