我有一个 Web 表单页面,它应该能够根据用户所做的选择将 Crystal Report 的内容写入 pdf 或 excel 文档。
我有两个问题:
对于 .pdf 和 .xls 扩展名,都有一个括号,其中一个括号被附加到扩展名 IE:fileName.xls'1 '
如果用户选择一个 excel 文档,在 IE 中会出现文件下载提示并询问我们是否要保存或打开文件:
PDF文件保存得很好,但是如果我们选择打开excel文件,它会打开一个资源管理器窗口,我们会得到垃圾......
这是我们的代码:
try
{
permission = new FileIOPermission(FileIOPermissionAccess.Read, output);
fs = File.Open(output, FileMode.Open, FileAccess.Read);
byte[] byteArray = new byte[fs.Length];
fs.Read(byteArray, 0, (int)fs.Length);
fs.Close();
fs.Dispose();
Response.Clear();
Response.ClearHeaders();
Response.ClearContent();
fileName = fileName + '.' + extn;
//Response.AddHeader("Content-Disposition", "attachments;filename=\"" + fileName + ".\"" + extn);
Response.AddHeader("Content-Disposition", "attachments;filename=\"" + fileName + "\"");
Response.AddHeader("Content-Length", byteArray.Length.ToString());
switch ("." + extn)
{
case ".pdf":
Response.AppendHeader("Content-Type", "application/pdf");
break;
case ".xls":
//Response.ContentType = "application/vnd.ms-excel";
//Response.ContentType = "application/octet-stream";
Response.AppendHeader(".xls", "application/excel");
//Response.AppendHeader("Content-Type", "application/vnd.ms-excel");
//Response.AppendHeader("Content-Type", "application/force-download");
break;
case ".txt":
Response.AppendHeader("Content-Type", "application/notepad");
break;
}
FileInfo info = new FileInfo(output);
info.Delete();
Response.BinaryWrite(byteArray);
Response.Flush();
Response.End();
}
catch (Exception ex)
{
if (fs != null)
fs.Close();
}
我一直在研究人们体验“ 1 ”被附加到扩展的现象,但是没有发现太多关于它并调试代码并确认扩展是干净的。
我的下一个猜测是 Response.BinaryWrite(byteArray); 行或 mime 类型或内容标题...
提前感谢您的帮助
道格