ASP.NET大文件上傳開發總結
ASP.NET大文件上傳開發總結(一)
以前開發過一個用Asp.NET上傳大文件的代碼,由于是在NET1.1下開發的,發現不能在NET.20下運行,前幾天將這個問題解決了,現在把整個開發過程整理一下,供大家參考。由于內容較多,所以我打算分成六篇來寫,第一篇寫一下需要解決的問題和大致解決思路,再用四篇具體寫一下開發中需要解決的四個主要問題,最后再寫一個組件的使用方法。
1、 問題提出:
使用ASP.NET大文件上傳時,IIS接收到請求內容后,發送到Asp.NET的管道中,然后Asp.NET的ISAPI將讀取的內容是全部裝入服務器內存(NET2.0在請求內容較大時,會存放到臨時文件中,見后面的開發說明),在上傳文件時,消耗服務器資源較多,所以Asp.NET對上傳文件的大小會有限制,且不能提供上傳進度顯示。而我們在實際應用中,往往會上傳較大的文件的現象,這時,可以通過修改配置文件將最大將求長度配置設置得很大,但這樣,服務器將會消耗大量內存。
為此,如果可以在IIS將客戶端發送的內容發送到Asp.NET的管道時,隨著服務器接收內容的同時,將文件內容寫到服務器磁盤中,然后在Asp.NET的管道中只放入請求的對應的Form內容。這樣可以避開ASP.NET大文件上傳的大小限制,同時提供服務器接收進度顯示。
2、 解決方案分析:
ASP.NET提供了HttpModule功能,提供了讓用戶處理客戶請求的手段,要實現HttpModule功能,用戶只需實現System.Web.IHttpModule接口。
System.Web.IHttpModule定義了兩個方法void Init (HttpApplication context)和void Dispose (),Init方法給我們提供了一個類型為HttpApplication的參數,這個HttpApplication類型中,給我們提供了處理Asp.NET頁面生命周期中發生的各種事件(具體請參照MSDN),我們只需要在最早的事件BeginRequest中,處理數據接收,就可以避開Asp.NET的最大請求長度限制。
為了不改變ASP.NET對頁面處理邏輯,我們需要在提供文件內容后,將其它請求內容正確封裝給Asp.NET,為此我們需要分析客戶端發送到服務器端內容的具體格式,我們可以通過其它工具,提供這些內容,這些內容大致如下:
- -----------------------------7d81e441d025c
- Content-Disposition: form-data; name="UploadID"
- de858d87-e8b8-4f7a-a832-357da2efdf13
- -----------------------------7d81e441d025c
- Content-Disposition: form-data; name="__VIEWSTATE"
- /wEPDwULLTIwODE1OTkzNTUPZBYCAgMPFgIeB2VuY3R5cGUFE
- 211bHRpcGFydC9mb3JtLWRhdGFkZAQ0pcd9kiSZ7/MOe0enKOTGFxMk
- -----------------------------7d81e441d025c
- Content-Disposition: form-data; name="TextBox1"
- -----------------------------7d81e441d025c
- Content-Disposition: form-data; name="TextBox2"
- -----------------------------7d81e441d025c
- Content-Disposition: form-data; name="file1";
- filename="C:\Documents and Settings\Administrator
- \??????\componentart.web.ui.rar"
- Content-Type: application/x-rar-compressed
- Rar! ??s這里我把文件具體內容去掉了,我們提取文件后,
- 封送給Asp.NET也就是去掉這部分后的內容。
- -----------------------------7d81e441d025c
- Content-Disposition: form-data; name="Button1"
- 開始上傳
- -----------------------------7d81e441d025c
- Content-Disposition: form-data; name="__EVENTVALIDATION"
- /wEWBAL1w7VGAuzRsusGAuzR9t
- kMAoznisYGMJIxZyapejeOQaIIwcOkPrWK6nE=
- -----------------------------7d81e441d025c--
我們封送給ASP.NET就應當時去掉文件內容后內容,這樣,頁面控件的值、頁面事件就會正確的發送到ASP.NET頁面。只是頁面不能正確獲取上傳文件的內容。
這里又出現了三個問題:一是:我們如何獲取文件內容,如何確定那部分內容是上傳的文件內容而不是頁面其它控件內容;二是:我們如何在提取文件內容后讓ASP.NET頁面正確獲取文件;三是:我們如何將改寫后的內容封送給ASP.NET,讓它感覺不到我們提取了文件內容。
只要解決了上面三個問題,那ASP.NET大文件上傳的問題就解決了,最后就是提供進度顯示,由于內容較多,我分四部分來介紹這三個問題和進度顯示。
【編輯推薦】