我可以从 ASP.NET 页面下载由内存流生成的 Excel 文件吗?

2024-01-18

我有一个 ASP.NET 页面,用户在其中提供 ID,然后我们从数据库中提取一些数据并将其放入 Excel 电子表格中。我想在内存中创建 Excel 文件,然后允许用户下载该文件。我可以在服务器上创建一个文件,然后删除它,但这似乎没有必要。根据错误处理,我可能会用这种方法孤立一个文件,等等。

这样的事情可能吗?或者我需要使用文件流?

顺便说一句,我正在使用EPPlus http://epplus.codeplex.com/作为 API(快速插件)。


您想要指定Content-Type and Content-Dispisition像这样的标题 -Response.ContentType = "application/vnd.ms-excel" 在 IE 和 Firefox 中有效,但在 Safari 中无效 https://stackoverflow.com/questions/4959732/response-contenttype-application-vnd-ms-excel-works-in-ie-and-firefox-but-no,然后流式传输您的文件。完成后,致电Response.End()停止应用程序的执行。

代码示例:

void StreamExcelFile(byte[] bytes)
{
    Response.Clear();
    Response.ContentType = "application/force-download";
    Response.AddHeader("Content-Disposition", "attachment; filename=name_your_file.xls");
    Response.BinaryWrite(bytes);
    Response.End();
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

我可以从 ASP.NET 页面下载由内存流生成的 Excel 文件吗? 的相关文章

随机推荐