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


報錯信息:

最近打開下載的 Excel,會報如下錯誤。(xls 格式不受影響)

解決方案:

下載代碼(紅色為新添代碼)

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();
    }
}

給下載加了個長度,解決問題。

Response.AddHeader("Content-Length", iStream.Length.ToString());

 


原文:asp.net NPOI導出xlsx格式文件,打開文件報“Excel 已完成文件級驗證和修復。此工作簿的某些部分可能已被修復或丟棄”


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM