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

相關文章
相關標籤/搜索