当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 如何让Web应用程序在Client端实现导出报表功能

ASP.NET
ReferenceEquals, == , Equals 比较
VB.NET窗口渐淡关闭
使用简单的DepthBuffer 和使用Lights
VB下使用adodb.command 执行存储过程注意
Sendkeys 和 Sendmessage 使用技巧一例
使用IndexBuffer(索引)
探讨C#中字符串的加密
常用加密算法
如何更新父窗体
当SESSION失效时自动转到其它页面
Sendkeys 和 Sendmessage 使用技巧一例 选择自 northwolves 的 Blog
1.DotNet(.Net):新平台,C#:新语言
Web下打印的实现
在.NET中实现彩色光标,动画光标和自定义光标[引自孟子前辈作品]
alert在asp.net中如何使用??
替换HTML代码
h2reg的一些使用经验
C#2.0 新特性探究(一) 模拟List和内置算法
在网页中添加Flash的播放或者背景音乐
Cookie 的写入与读取

ASP.NET 中的 如何让Web应用程序在Client端实现导出报表功能


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 127 ::
收藏到网摘: n/a

在Web应用程序中,我们无法像在Windows应用程序那样导出报表,因为程序是在服务器端执行的,执行导出时,其结果也是在服务器端,那应该如何才能实现完整的客户端导出呢?其实这个也不难,方法是:把报表指定导出到某个网站上事先建立好的报表暂存文件,然后利用response.redirect()指令,将浏览器网址指向该报表位置,这样用户的浏览器就会尝试下载刚导出的文件,文件就会被下载到客户端,从而实现我们需要的效果。部分代码如下:

publicstringExportReport()
{
ExportOptionscreo=newExportOptions();
DiskFileDestinationOptionscrdo=newDiskFileDestinationOptions();
stringFileName=Request.PhysicalApplicationPath+"ExportFile\Exap.xls";

//设置导出选项
creo=Myrpt.ExportOptions;
creo.ExportFormatType=ExportFormatType.Excel;
creo.ExportDestinationType=ExportDestinationType.DiskFile;

//设置磁盘文件选项
crdo.DiskFileName=FileName;
creo.DestinationOptions=crdo;

//导出报表
MyRpt.Export();
returnFileName;
}

privatevoidbuttonExport_Click(objectsender,System.EventArgse)
{
stringFileName=ExportReport();
Response.Redirect(Replace(FileName,Request.PhysicalApplicationPath+"ExportFile\",""));
}


要注意的是:当在web中进行导出时,需要对导出目录具有建立文件的权限,如果权限不足,将会出现“拒绝访问报表文件……”的错误。让ASPNET用户(安装.NETFramework时自动生成的系统用户)在导出目录文具有“写入”权限即可。