報錯信息:html
最近打開下載的 Excel,會報以下錯誤。(xls 格式不受影響)瀏覽器
解決方案:服務器
下載代碼(紅色爲新添代碼)app
public void download() { string fileName = "456.zip";//客戶端保存的文件名 string filePath = AppDomain.CurrentDomain.BaseDirectory.Replace("\\", "/") + "Excel/123.zip"; System.IO.FileInfo fileInfo = new System.IO.FileInfo(filePath); if (fileInfo.Exists == true) { //每次讀取文件,只讀取1M,這樣能夠緩解服務器的壓力 const long ChunkSize = 1048576; byte[] buffer = new byte[ChunkSize]; Response.Clear(); //獲取文件 System.IO.FileStream iStream = System.IO.File.OpenRead(filePath); //獲取下載的文件總大小 long dataLengthToRead = iStream.Length; //二進制流數據(如常見的文件下載) Response.ContentType = "application/octet-stream"; //通知瀏覽器下載文件而不是打開 Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(fileName)); //加上設置大小下載下來的.xlsx文件打開時纔不會報「Excel 已完成文件級驗證和修復。此工做簿的某些部分可能已被修復或丟棄」 Response.AddHeader("Content-Length", iStream.Length.ToString()); using (iStream)//解決文件佔用問題,using 外 iStream.Dispose() 沒法釋放文件 { while (dataLengthToRead > 0 && Response.IsClientConnected) { int lengthRead = iStream.Read(buffer, 0, Convert.ToInt32(ChunkSize));//讀取的大小 Response.OutputStream.Write(buffer, 0, lengthRead); Response.Flush(); dataLengthToRead = dataLengthToRead - lengthRead; } iStream.Dispose(); iStream.Close(); } Response.Close(); Response.End(); } }
給下載加了個長度,解決問題。asp.net
Response.AddHeader("Content-Length", iStream.Length.ToString());
原文:asp.net NPOI導出xlsx格式文件,打開文件報「Excel 已完成文件級驗證和修復。此工做簿的某些部分可能已被修復或丟棄」post