4

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

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

附带说明一下,我使用EPPlus作为 API(快速插入它)。

4

4 回答 4

10

您想像这样指定content-typecontent-dispisition标头- Response.ContentType = "application/vnd.ms-excel" 在 IE 和 firefox 中有效,但在 Safari中无效,然后流式传输您的文件。完成后,调用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();
}
于 2012-03-19T20:19:21.690 回答
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();
于 2013-04-12T07:58:37.000 回答
1

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

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

于 2012-03-19T20:15:37.817 回答
0

您正在寻找的称为通用处理程序:

http://www.dotnetperls.com/ashx

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

他们将被提示下载文件。

于 2012-03-19T20:14:16.410 回答