- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有许多页面需要支持将数据导出到 Excel 电子表格。我可以很好地生成 Excel 文件,但我正在尝试弄清楚如何抽象出这种行为,以便它可以很容易地从我需要它的所有页面中重用。我目前的想法是使用静态实用方法,如下:
public static void SendExcelFile(System.Web.UI.Page callingPage, string downloadFileName, List<List<string>> data, string worksheetTitle)
{
string tempFileName = Path.GetTempFileName();
try
{
// Generate file using ExcelPackage
GenerateExcelDoc(tempFileName, data, worksheetTitle);
callingPage.Response.AddHeader("Content-Disposition", "attachment;filename=" + downloadFileName);
callingPage.Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
callingPage.Response.AddHeader("Content-Length", new FileInfo(tempFileName).Length.ToString());
callingPage.Response.TransmitFile(tempFileName);
}
finally
{
//When this is removed, the method works as expected.
if (File.Exists(tempFileName))
File.Delete(tempFileName);
}
}
我调用 SendExcelFile
的点击处理程序如下所示:
protected void lnkExport_Click(object sender, EventArgs e)
{
List<List<string>> dataList = GatherDataForSpreadsheet();
Utility.SendExcelFile(this, "fileNameForDownload.xlsx", dataList, "MyReports");
}
此代码作为调用页面的实例方法工作得很好。但是,作为静态方法,它根本不起作用。当我单击调用它的按钮时,浏览器无限期地显示加载动画,但从不提示下载文件。
我对 ASP.NET(和一般的 Web 编程)还很陌生,所以我确定我在这里遗漏了一些东西。有人可以解释我所看到的行为,并提出一种合理的替代方法吗?
编辑:如果我在最后删除对 File.Delete() 的调用,该方法将按预期工作。 Response.TransmitFile() 是否异步进行传输?
编辑 2:我只需要在删除文件之前调用 Response.Flush()。请参阅下面的答案。谢谢!
最佳答案
问题是临时文件在数据发送之前被删除了。我只需要像这样调用 Response.Flush() :
public static void SendExcelFile(System.Web.UI.Page callingPage, string downloadFileName, List<List<string>> data, string worksheetTitle)
{
string tempFileName = Path.GetTempFileName();
try
{
// Generate file using ExcelPackage
GenerateExcelDoc(tempFileName, data, worksheetTitle);
callingPage.Response.AddHeader("Content-Disposition", "attachment;filename=" + downloadFileName);
callingPage.Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
callingPage.Response.AddHeader("Content-Length", new FileInfo(tempFileName).Length.ToString());
callingPage.Response.TransmitFile(tempFileName);
callingPage.Response.Flush(); //This is what I needed
}
finally
{
if (File.Exists(tempFileName))
File.Delete(tempFileName);
}
}
关于c# - 从静态方法调用 Response.TransmitFile(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2275894/
TransmitFile 的文档winsock 函数确实说"file"而不是“文件描述符”,所以答案是否定的?如果我不能使用 TransmitFile 通过套接字从管道发送数据,是否可以使用其他一些零
传递的参数是: `C:\Licenses\testfolder\PERSONAL-Wednesday 04 July-0405.txt`,`c2license.txt` 函数是: /// /// S
我正在使用 TransmitFile功能,它正在做一些与我预期不同的事情。 最小的例子: #include int main(void) { WSADATA wsa; SOCKET
在 C# ASP.Net 网站中,将文件传输到我正在使用的客户端 String file_path = Server.MapPath("~/files/"+file_name); HttpContex
我的服务器上或本地主机上有一个文件。我想使用以下代码将其传输给用户: Response.ContentType = "application/pdf"; Respons
我有以下方法可用于在访问页面时下载文件。问题在于它似乎会产生带有附加字节的文件,基于文件类型的文件可能会使其损坏。我有以下方法: Public Class GetImage Inherits
我有许多页面需要支持将数据导出到 Excel 电子表格。我可以很好地生成 Excel 文件,但我正在尝试弄清楚如何抽象出这种行为,以便它可以很容易地从我需要它的所有页面中重用。我目前的想法是使用静态实
所以我有了过去几天一直在玩弄的代码集,我需要从服务器下载一个文件到客户端。这是简单的部分,但我还需要在完成后刷新 GridView 并在警报中显示文件已成功创建,但我发现下载的每种方式都包含一个选择代
我正在使用 Response.TransmitFile 从 Web 服务检索文件。我想从服务器的角度衡量这个过程所花费的时间。 我试过在这个调用之前和之后获取滴答计数,但这显然不能代表传输花费了多长时
我正在尝试通过使用发送一个 xlsx 文件 Response.Clear(); Response.AddHeader("Content-Disposition", "attachment; filen
我必须在我的站点中实现 GEDCOM 导出。 单击导出到 gedcom 时,我的 .net 代码在服务器上创建了一个文件。 然后我需要将它从服务器下载到客户端,并且应该询问用户该文件的保存位置,这意味
如果我还想使用加密,如何获得 sendfile()(在 Linux 上)和 TransmitFile()(在 Windows 上)的好处?是否有任何提供此功能的 Linux 内核模块或 Windows
我有以下代码: try { context.Response.TransmitFile(savedFileName); } catch (Exception ex) { Excepti
我正在尝试使用 Response.TransmitFile() 来提示下载。我已经阅读了很多关于这个问题的帖子,并且我的方法基于 Rick Strahl 的博客 http://www.west-win
下面是有问题的代码,我下载了一个 csv,但是它在底部附加了页面源代码关于如何防止这种情况的任何想法? var priceList = Test();
首先,介绍一下背景 --我正在为个人项目编写一个基本的 FTP 服务器。我目前正在检索文件。我当前的实现如下所示: HANDLE hFile = CreateFile("file.tar.gz", G
我正在为类使用 Winsocket 编写一个小型服务器/客户端文件传输,它基本上可以工作,除了在我收到文件并将其写入我的硬盘后无法在套接字上收到任何更多消息。 传输代码看起来像这样: long
我必须触发用户将大文件下载到网络浏览器,我在其中创建要在服务器上传输的文件,然后立即将其删除。我已经找到了足够多的示例,可以看出我应该使用 Response.TransmitFile 或 Respon
我目前正在使用 HttpResponse 从我的服务器下载文件。我已经有几个函数可用于下载 Excel/Word 文件,但我无法下载我的简单文本文件 (.txt)。 对于文本文件,我基本上是将 Tex
我的问题是,当我从对话框后面的代码调用关闭对话框时,使用引用的 aspx 页面不会关闭。如果我注释代码的响应传输文件部分,则对话框正确关闭,否则下载开始但对话框保持打开状态。如果您有任何建议,请告诉我
我是一名优秀的程序员,十分优秀!