步骤一:看示例文件
水晶报表自带一个示例文件,数据库是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; } |
【水晶报表】.NET權限問題
最新推荐文章于 2024-09-03 10:34:44 发布