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

时间:2012-03-19 20:12:04

标签: c# asp.net excel epplus

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

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

另外,我正在使用EPPlus作为API(快速插件)。

4 个答案:

答案 0 :(得分:9)

您想要指定content-typecontent-dispisition标头,如{ - 3}},然后流式传输您的文件。完成后,调用Response.End()以停止应用程序执行

代码示例:

void StreamExcelFile(byte[] bytes)
{
    Response.Clear();
    Response.ContentType = "application/force-download";
    Response.AddHeader("content-disposition", "attachment; filename=name_you_file.xls");
    Response.BinaryWrite(bytes);
    Response.End();
}

答案 1 :(得分:3)

ExcelPackage pck = new ExcelPackage();
.....
.....
.....

byte[] bfr = pck.GetAsByteArray();
Response.ContentType = "application/application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
Response.AppendHeader("content-disposition", "attachment; filename=ExcelFileName.xlsx");

Response.OutputStream.Write(bfr, 0, bfr.Length);
Response.Flush();
Response.Close();

答案 2 :(得分:1)

是的,请查看使用HTTP处理程序将文件从内存流式传输到浏览器。

http://msdn.microsoft.com/en-us/library/ms972953.aspx

答案 3 :(得分:0)

您正在寻找的是一个通用处理程序:

http://www.dotnetperls.com/ashx

简而言之,您需要做的是定义上下文类型。在您的情况下,将是xls或xlsx。设置响应,并将用户定向到处理程序。

将提示他们下载文件。