您好,登錄后才能下訂單哦!
本篇內容介紹了“Asp.net大文件下載的實現方法介紹”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
文件下載是一個網站最基本的功能,ASP.NET網站的文件下載功能實現也很簡單,但是如果遇到大文件的下載而不做特殊處理的話,那將會出現不可預料的后果。當我們的網站需要支持下載大文件時,如果不做控制可能會導致用戶在訪問下載頁面時發生無響應,使得瀏覽器崩潰。可以參考如下代碼來避免這個問題。
using System; namespace WebApplication1 { public partial class DownloadFile : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { System.IO.Stream iStream = null; // Buffer to read 10K bytes in chunk: byte[] buffer = new Byte[10000]; // Length of the file: int length; // Total bytes to read. long dataToRead; // Identify the file to download including its path. string filepath = Server.MapPath("/") +"./Files/TextFile1.txt"; // Identify the file name. string filename = System.IO.Path.GetFileName(filepath); try { // Open the file. iStream = new System.IO.FileStream(filepath, System.IO.FileMode.Open, System.IO.FileAccess.Read, System.IO.FileShare.Read); // Total bytes to read. dataToRead = iStream.Length; Response.Clear(); Response.ClearHeaders(); Response.ClearContent(); Response.ContentType = "text/plain"; // Set the file type Response.AddHeader("Content-Length", dataToRead.ToString()); Response.AddHeader("Content-Disposition", "p_w_upload; filename=" + filename); // Read the bytes. while (dataToRead > 0) { // Verify that the client is connected. if (Response.IsClientConnected) { // Read the data in buffer. length = iStream.Read(buffer, 0, 10000); // Write the data to the current output stream. Response.OutputStream.Write(buffer, 0, length); // Flush the data to the HTML output. Response.Flush(); buffer = new Byte[10000]; dataToRead = dataToRead - length; } else { // Prevent infinite loop if user disconnects dataToRead = -1; } } } catch (Exception ex) { // Trap the error, if any. Response.Write("Error : " + ex.Message); } finally { if (iStream != null) { //Close the file. iStream.Close(); } Response.End(); } } } }
關于此代碼的幾點說明:
1. 將數據分成較小的部分,然后將其移動到輸出流以供下載,從而獲取這些數據。
2. 根據下載的文件類型來指定 Response.ContentType 。(參考OSChina的這個網址可以找到大部分文件類型的對照表:http://tool.oschina.net/commons)
3. 在每次寫完response時記得調用 Response.Flush()
4. 在循環下載的過程中使用 Response.IsClientConnected 這個判斷可以幫助程序盡早發現連接是否正常。若不正常,可以及早的放棄下載,以釋放所占用的服務器資源。
5. 在下載結束后,需要調用 Response.End() 來保證當前線程可以在最后被終止掉。
“Asp.net大文件下載的實現方法介紹”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。