C# Aspose.Cells導出xlsx格式Excel,打開文件報「Excel 已完成文件級驗證和修復。此工做簿的某些部分可能已被修復或丟棄」

報錯信息: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 已完成文件級驗證和修復。此工做簿的某些部分可能已被修復或丟棄」spa

相關文章
相關標籤/搜索