我使用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();
}
只需要使用.Save
重载和密码作为选项:
package.Save("password");
回应评论
要通过byte
数组保存时应用密码,它非常相似:
Byte[] bin = pck.GetAsByteArray("password");
System.IO.File.WriteAllBytes(fullFilePath, bin);
它没有记录,但您可以执行以下操作:
package.Encryption.Password = "your password here";
然后使用您选择的Save()
或GetAsByteArray()
为您的包裹提供服务
如果要将excel包保存到MemoryStream(用于作为电子邮件附件发送),则必须执行以下操作:
excelPackage.SaveAs(memoryStream, "pa$$w0rd");