6

我有一个存储一些文档的 sql 数据库。

用户可以登录应用程序,并查看他们的文档列表。

在他们的文档的网格视图中单击链接按钮下载时,我从数据库中获取文件,将其写入文件系统,然后执行此代码。

    System.IO.FileInfo file = new System.IO.FileInfo(System.Configuration.ConfigurationManager.AppSettings["UploadPath"] + DocumentName);

    Response.Clear();
    Response.ClearContent();
    Response.ClearHeaders();
    Response.Cookies.Clear();
    Response.Cache.SetCacheability(HttpCacheability.Private);
    Response.CacheControl = "private";
    Response.Charset = System.Text.UTF8Encoding.UTF8.WebName;
    Response.ContentEncoding = System.Text.UTF8Encoding.UTF8;
    Response.AppendHeader("Content-Length", file.Length.ToString());
    Response.AppendHeader("Pragma","cache");
    Response.AppendHeader("Expires", "60");
    Response.ContentType = GetContentType(file.Extension);
    Response.AppendHeader("Content-Disposition",
    "inline; " +
    "filename=\"" + file.Name + "\"; " +
    "size=" + file.Length.ToString() + "; " +
    "creation-date=" + DateTime.Now.ToString("R") + "; " +
    "modification-date=" + DateTime.Now.ToString("R") + "; " +
    "read-date=" + DateTime.Now.ToString("R"));

我的 GetContentType() 方法只为我允许的文件返回适当的文件类型“application/pdf、application/msw0rd 等。

我的问题是,当文件被保存时,它是网页本身,而不是文件系统中的文件。在谷歌浏览器中,它在文件名的末尾添加了一个 .htm 扩展名,我猜是因为它知道这是一个网页?

无论如何,第一步是获取实际文件,而不是他们所在的 HTML 网页副本!

谢谢。

4

3 回答 3

9

代替

Response.AppendHeader("Content-Disposition", "inline;" + "filename=

采用

Response.AddHeader("content-disposition:", "attachment;filename=

于 2008-12-03T06:51:29.050 回答
9

您如何发送文件的实际内容?

我通常使用Response.TransmitFile方法,它基本上打开文件并将其内容发送到 Response.OutputStream

于 2008-12-03T07:14:25.527 回答
3

您是否尝试将内容处置设置为“附件”而不是“内联”?我相信浏览器会提示用户打开或保存文档。

此外,您通常可以通过使用 BinaryWrite 方法将数据库中的字节流直接写入 Response 对象来绕过文件系统...这也是您可能希望在 ASPX 页面上使用 HTTP 处理程序而不是进行调查的情况,所以您无需担心清除响应等。我过去曾在页面上使用隐藏的 iframe,然后使用 Javascript 将其 src 设置为 HTTP 处理程序,该处理程序将文档 ID 作为参数在查询字符串上。

于 2008-12-03T06:29:48.907 回答