.net水晶报表的文章

241
步骤一:看示例文件
水晶报表自带一个示例文件,数据库是access(不带密码的)。我首先运行示例文件(基于webform和winform)结果显示了正确的报表,正如“飞刀”的示例。
于是,我自己建立了一个报表文件和.aspx文件,结果显示登陆失败!可是我把报表文件换成示例的报表文件,不再出错。
问题出在什么地方?难道是报表格式文件有关于登陆权限的设置?通过跟踪、调试,我对比分析我的报表文件和示例报表文件,没有发现任何的不同。看来问题不在报表文件。
是数据库的问题?我建立一个access结果还是登陆失败!
不是数据库的问题(我自己的数据库是未带密码的access,帮助中的数据库也是如此)?也不是报表格式文件的问题(我仔细分析了两者的原代码是相同的)?
那么问题出现在什么地方?我白思不得其解!
步骤二:找帮助文件
于是我再次求助于帮助。我翻遍了水晶报表的帮助,终于找到“   访问安全数据库   [C#]”字样,发现这里有下面的一段话:
通过   Crystal   Reports   for   Visual   Studio   .NET   访问安全数据库的过程在   Web   窗体和   Windows   窗体之间有所不同。在   Windows   窗体中,对话框自动提示用户输入用户名和密码(测试很容易成功)。而在   Web   窗体中,您需要设计一个表单以从用户获取该信息。对于这两种情况,均可使用代码来指定用户名和密码,从而为应用程序的所有用户提供相同的安全等级。
于是我对同样的数据库(先是用帮助示例中的access数据库,后来用自己建立的access数据库)。发现对于同一个报表文件,对于winform能显示成功,而对于webform则仍然显示登陆失败!于是我有点明白上面的意思!
看来问题是出在权限的设置上。  
步骤三:研究帮助,终于成功!
在帮助里我找到“设置数据库登录参数”字样,里面提供了一些后来发现是非常有用的信息:
下列示例说明如何将登录参数传递到报表的表中。该示例使用到某个安全的   SQL   Server   数据库的连接。  
启动一个新项目  
向窗体添加一个“按钮”和四个“文本框”控件。  
将“文本框”控件分别命名为:serverNameTxt、dbNameTxt、userNameTxt   和   passwordTxt。  
双击“按钮”控件以指定   Click   事件的代码。根据所用语言插入适当的代码。
[C#]  
//   声明所需变量。
TableLogOnInfo   logOnInfo   =   new   TableLogOnInfo   ();
int   i   =   0;
//   对报表中的每个表依次循环。
for   (i=0;i   ==   Report.Database.Tables.Count   -   1;i++)
{
//   设置当前表的连接信息。
logOnInfo.ConnectionInfo.ServerName   =   serverNameTxt.Text;
logOnInfo.ConnectionInfo.DatabaseName   =   dbNameTxt.Text;
logOnInfo.ConnectionInfo.UserID   =   userNameTxt.Text;
logOnInfo.ConnectionInfo.Password   =   passwordTxt.Text;
Report.Database.Tables   [i].ApplyLogOnInfo   (logOnInfo);
}
注意   受密码保护的   Microsoft   Access   和   Paradox   等   PC   数据库也使用该方法,但   LogOnInfo.ServerName   和   LogOnInfo.DatabaseName   要保留为空。
于是我仿照这个样子,尝试了一下,出错提示:没有发现TableLogOnInfo   和Report。
后来我发现TableLogOnInfo   是属于CrystalDecisions.Shared   命名空间的成员。于是我添加引用:
using   CrystalDecisions.Shared   ;
这次问题出现在Report。
Report?这是个什么东西,我查遍了所有的帮助,并没有这个函数或类!
[说真的!这个问题难到了我很长的时间!一直在查找Report到底是个什么东西!水景报表公司也真是的,帮助也不写得详细一点!该打!!!]
最终我终于发现Report只是一个用户定义的对象,不是系统本身的对象。
在我困惑的时候,突然我想,为什么不看看Report后面的DataBase,这是个什么东西,终于问题解决了,在帮助里找到如下信息
ReportDocument   oRpt   =   new   ReportDocument();
Report属于DocumentCrystalDecisions.CrystalReports   .Engine   类的成员。
修改代码:并添加引用
using   CrystalDecisions.Shared   ;//负责解释TableLogOnInfo类
using   CrystalDecisions.CrystalReports   .Engine   ;//负责解释ReportDocument类private   void   Page_Load(object   sender,   System.EventArgs   e)
{
TableLogOnInfo   logOnInfo   =   new   TableLogOnInfo   ();
//这里必须事先申明一个ReportDocument对象   Report,同时加载数据报表
ReportDocument   oRpt   =   new   ReportDocument();
oRpt.Load("c:\\inetpub\\wwwroot\\exer\\pagelet\\crystal\\cr1.rpt");//修改为你自//己的正确位置
//建立安全信息
//受密码保护的   Microsoft   Access   和   Paradox   等   PC   数据库也使用该方法,但   LogOnInfo.ServerName   //和   LogOnInfo.DatabaseName   要保留为空
logOnInfo.ConnectionInfo.ServerName   =   "www";
logOnInfo.ConnectionInfo.DatabaseName   =   "archives";
logOnInfo.ConnectionInfo.UserID   =   "sa";
logOnInfo.ConnectionInfo.Password   =   "123456";
oRpt.Database   .Tables   [0].ApplyLogOnInfo   (logOnInfo);
//建立.rpt文件与CryStalReportviewer文件之间的连接
CrystalReportViewer1.ReportSource   =   oRpt;
}
报表文件终于出现!
哇,我好高兴,禁不住站起来伸了个懒腰!
步骤四:最终的完整版的代码
上面的代码不具有系统可扩充和灵活性。缺点有二:
(1)、数据报表格式文件是采用绝对路径
(2)、数据库访问权限的设置一旦设定,在最终发布是无法修改的,特别是客户的SQL   SERVER服务器不可能和你调试的程序环境是一样的
基于这个考虑。引进两个比较好的东西:
(1)、Server.Mappath函数
(2)、读取web.config(本示例同时告诉你如何操作web.config配置文件)
最终修改如下:(完整代码)数据库为sql   server2000
using   CrystalDecisions.Shared   ;//负责解释TableLogOnInfo类
using   CrystalDecisions.CrystalReports   .Engine   ;//负责解释ReportDocument类
private   void   Page_Load(object   sender,   System.EventArgs   e)
{
TableLogOnInfo   logOnInfo   =   new   TableLogOnInfo   ();
//这里必须事先申明一个ReportDocument对象   Report,同时加载数据报表
ReportDocument   oRpt   =   new   ReportDocument();
//获取.rpt文件真实路径
string   path1,path2;
path1=Server.MapPath   ("\\exer\\pagelet");
path2=path1+"\\crystal\\cr1.rpt";
//oRpt.Load("c:\\inetpub\\wwwroot\\exer\\pagelet\\crystal\\cr1.rpt");
oRpt.Load   (path2);
//从web.config中获取logOnInfo参数信息
string   a,b,c,d;
//获取ServerName
a=System.Configuration   .ConfigurationSettings   .AppSettings   ["servername"];
//获取DatabaseName
b=System.Configuration   .ConfigurationSettings   .AppSettings   ["database"];
//获取UserId
c=System.Configuration   .ConfigurationSettings   .AppSettings   ["userid"];
//获取password
d=System.Configuration   .ConfigurationSettings   .AppSettings   ["pass"];
//设置logOnInfo参数
logOnInfo.ConnectionInfo.ServerName   =   a;
logOnInfo.ConnectionInfo.DatabaseName   =   b;
logOnInfo.ConnectionInfo.UserID   =   c;
logOnInfo.ConnectionInfo.Password   =   d;
oRpt.Database   .Tables   [0].ApplyLogOnInfo   (logOnInfo);
//建立.rpt文件与CryStalReportviewer文件之间的连接
CrystalReportViewer1.ReportSource   =   oRpt;
}

Layer弹出确认框的使用方法

Layer是一个流行的Web弹层组件,可以方便地创建各种弹出框,包括确认框。以下是使用Layer创建确认框的几种方式:...

php求两个数组的差集

要计算两个数组的差集,即找出在第一个数组中存在但在第二个数组中不存在的元素。...

无人货架批量大规模上架商品解决方案

架构设计之初未考虑到业务需要批量上架商品,几万个逐一生成货架商品需要耗费大量人力,而货架商品的结构数量都一样。...

物业小区无人销售智能货架方案

小区无人值守货架销售的建设方案,从三个方面阐述货架集成建设,投入使用,系统管理。...

厨余收运管理系统迭代开发,回收系统优化升级

完成基础数据开发,试运行一段时间后,在数据沉淀的基础上对数据进行挖掘,对业务处理进行优化升级。...

餐厨油脂再生资源收运回收管理系统方案

通过互联网+改变餐厨收运回收传统工作方式,移动手机助力系统提供工作效率、’管理效率,数据电子化打造收运大数据建设。...

医馆诊所管理系统

实现中医馆中诊所,理疗的业务处理,分为小程序用户端,医生端,管理端,PC管理端,PC服务台,PC医生端...

thinkphp8安装VIEW,多应用,验证码

官方THKPHP8默认只有单应用一个控制器,其他插件可按需安装,通常需要VIEW和多应用...

sqlserver中的nvarchar和varchar的区别

数据库表中nvarchar和varchar都可以用来表示字符的存储类型。...

微信接口开发返回码一览表

返回错误码对照表...

0.091434s