相關(guān)關(guān)鍵詞
關(guān)于我們
最新文章
PHP 文件上傳后端處理實用技巧方法
PHP 文件上傳后端處理實用技巧方法
引語:在上一篇文章中說到,在頁面中可以用隱藏的方式讓你的上傳頁面看起來漂亮。但是這對于性能來說,并沒有什么卵用,那么在后臺的處理中,難道就沒有一些處理技巧么?所謂后臺的技巧,應(yīng)該要包括上傳得快一點,上傳的文件大一點!那么,本文就來說說,后端處理都有些什么技巧吧!
業(yè)務(wù)場景一、我們只會選擇一個單個的文件上傳,而且不需要做一些即時的驗證工作。那么,也許并沒有什么優(yōu)化可言了,因為,最后你要做的,只是將這個文件放在表單里最后一起提交,直接處理即可!
業(yè)務(wù)場景二、需要上傳多個文件,而且需要時時驗證文件內(nèi)部內(nèi)容,并時行相應(yīng)頁面顯示。對于這種況,在用戶選擇了上傳文件之后,我們需要立即將文件上傳,因為我們需要讀取文件里的信息,在最后提交的時候,我們也需要提交一次文件。很明顯,在這里是存在一個重復(fù)上傳的工作的,一個耗費用戶時間,二個是耗費服務(wù)器帶寬資源!優(yōu)化,能夠想得到的方法也很簡單,能不能在第一次上傳完文件之后,就將文件保留在服務(wù)器,真正提交表單的時候,去讀取這個已經(jīng)被上傳的臨時文件即可。是的,這就是我們的處理思路!
業(yè)務(wù)場景三、與場景二類似,需要上傳多個文件,但是多個文件可能是分開上傳的。即我們可能第一次上傳了10M,第二次上傳了10M,總共上傳了10次,那么,在服務(wù)器端來說的話,一次性提交肯定是超出了上傳大小的限制了,但是如果,我們是分每一次的上傳,這是可以的,而最后提交的時候,我們只需要將簡短的文本信息傳上去即可!
思路的確是簡單的,看起來,也是沒什么問題,但是,也許我是能力有限,當(dāng)時著實花了我不少時間去處理這個什么鬼!下面,我將給出一些示例代碼,以供參考:
文件上傳技巧(將單次上傳的文件作為臨時文件存在在服務(wù)器端)示例代碼:
1. 頁面js處理
//點擊選擇完成文件后,觸發(fā)上傳文件操作,將文件上傳至服務(wù)器臨時目錄 $('.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 自動關(guān)閉 });