密码保护的Excel使用EPPLUS下载

问题描述 投票:3回答:3

我使用EPPLUS Excel库以Excel格式导出数据。我希望当excel下载时会询问密码。我试过以下代码。

FileInfo newFile = new FileInfo("sample.xlsx");
using (ExcelPackage package = new ExcelPackage(newFile)
{
    ExcelWorksheet ws = package.Workbook.Worksheets.Add("demo");
    ws.Cells[A1].LoadFromDataTable(dataTable, false);
    package.Workbook.Protection.SetPassword("EPPLUS");
    package.Save();
}
c# asp.net-mvc asp.net-mvc-4 epplus
3个回答
17
投票

只需要使用.Save重载和密码作为选项:

package.Save("password");

回应评论

要通过byte数组保存时应用密码,它非常相似:

Byte[] bin = pck.GetAsByteArray("password");
System.IO.File.WriteAllBytes(fullFilePath, bin);

3
投票

它没有记录,但您可以执行以下操作:

package.Encryption.Password = "your password here";

然后使用您选择的Save()GetAsByteArray()为您的包裹提供服务


0
投票

如果要将excel包保存到MemoryStream(用于作为电子邮件附件发送),则必须执行以下操作:

excelPackage.SaveAs(memoryStream, "pa$$w0rd");
© www.soinside.com 2019 - 2024. All rights reserved.