手机站
网通分站
电信主站
密 码:
用户名:
当前位置 : 主页>网络编程>Asp.Net编程>列表

在系统中生成Excel流并传给用户

来源:互联网 作者:west263.com 时间:2008-02-22
西部数码-全国虚拟主机10强!40余项虚拟主机管理功能,全国领先!双线多线虚拟主机南北访问畅通无阻!免费赠送企业邮局,.CN域名,自助建站480元起,免费试用7天,满意再付款! P4主机租用799元/月.月付免压金!

在系统中经常出现这样的情况就是生成excel流 并将生成的Excel 流传给用户

一般的来讲

可以利用 Response 来向客户端发送一个HTTP头 ,并将Excel流发送出去就可以

但会出现一个问题

就是点击打开的时候会出现两次 文件下载 对话框

主要的原因:(现在的猜测,还没有找到准确的原因)。

第一次打开 时 ,在系统中已经存在了excel流的临时文件(就是文件,没有文件的后缀名的存在) ,但没有原来的(真实文件的存在),要求用户是否将临时文件保存到计算机其他的位置上。(是否跟没有后缀名有关)

第二次 ,选择客户端文件的位置,是否保存到其他的非临时文件夹位置。

现在的解决方案是

新建一个页面专门提供导出数据的

在这个页面中的Page_load中写这样的代码


private void Page_Load(object sender, System.EventArgs e)

{

// 在此处放置用户代码以初始化页面
ReportRule reportRule=new ReportRule();
byte[] result= reportRule.RenderReport(HttpContext.Current.Server.UrlDecode(this.Request.QueryString["peportpath"]),Request.QueryString["id"]); //生成excel流

HttpContext.Current.Response.ContentType = "application/vnd.ms-excel";

HttpContext.Current.Response.AppendHeader("Content-disposition","attachment;filename=hahh.xls");

HttpContext.Current.Response.BinaryWrite(result);

HttpContext.Current.Response.End();

}

文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!