`
cab0605
  • 浏览: 108675 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

水晶报表读取Web.config 登陆设置

阅读更多

 大家在基于webform中使用水晶报表时如果简单的按照网上“阿刀”的做法,肯定会提示你:登陆失败。  
对于这个问题,斑竹我花了整整一天的时间研究水晶报表的帮助文件,终于得到解决方案。  
我不是一个保守的人,我相信有很多的网友正和我一样在花费精力在研究这个问题,我不愿意大家再和我一样白白的花费精力。  
下面是我实现该方案的几个步骤。大家不要着急,慢慢的看下去会对你有很大的帮助。  
步骤一:看示例文件  
水晶报表自带一个示例文件,数据库是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;  
}  
   
   
整个演示的操作过程说明:  
1、   在解决方案资源管理器里,你需要存放报表文件处,添加新项:CrystalReport报表,起名为cr1.rpt  
2、   在随后出现的“报表专家”中选择数据源时,请务必选择OLE   DB,然后根据你的数据库的要求选择响应的驱动引擎:  
SQL   SERVER:Microsoft   OLE   DB   Provider   for   SQL   server  
Access:Microsoft   Jet.4.0  
3、   输入正确的数据库连接,这一步大家一般的情况下不会出错!  
4、   建立数据报表,并保存cr1.rpt文件  
5、   打开webform1.aspx。添加crystalreportviewer控件:名称为:CrystalReportViewer1  
6、   在webform1.aspx.cs中的page_load事件中添加上面的代码:  
(注意:引用千万不要忘了!)  
   
   
*****************************************************  
下面是web.config中与本内容有关的细节  
<appSettings>  
<add   key="servername"   value="www"/>  
<add   key="database"   value="archives"/>  
<add   key="userid"   value="admin"/>  
<add   key="pass"   value="123456"/>  
</appSettings>  
   
   
***注意这里的<add   key="pass"   value="123456"/>是pass,所以他必须与  
//获取password  
d=System.Configuration   .ConfigurationSettings   .AppSettings   ["pass"];这里  
的AppSettings["pass"]   中的"pass"保持一致。   当然名字是可以随便起,但必须一致

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/luchuanbo/archive/2009/05/18/4198195.aspx

分享到:
评论
1 楼 吉米家 2015-02-02  
水晶报表的话,登录的确不是很好用,相比之下,帆软报表更加实用一些

相关推荐

    ASP.NET CrystalReport水晶报表访问时提示登录的解决方法

    ASP.NET CrystalReport 水晶报表访问时提示登录的解决方法 在 ASP.NET 环境中使用 CrystalReport 水晶报表时,可能会遇到访问报表时提示登录的問題。这是因为 CrystalReport 需要连接数据库才能显示报表内容,而...

    VS2005水晶报表一个精典错误完美解决方法

    检查这些信息是否在应用程序的配置文件(如app.config或web.config)中正确设置,并且在运行时能够被水晶报表正确读取。 2. **参数传递不正确**:如果报表依赖于用户输入的参数,那么在调用报表时需要确保所有必要...

    IFS9水晶报表开发流程

    4. 将开发完水晶报表上传到 IFS 水晶报表服务器:设置路径路 径 位 置 设 置 参 数 文 件 路 径 : Eg:C:\inetpub\wwwroot\IFSCRWebSetup\Web.Config路 径 由 安 装 完 水 晶 报 表 服 务 器 后 , 在 安 装 路 径 ...

    水晶报表示例

    在实际应用中,“水晶报表示例”可能包含多个文件,如.aspx页面(Asp.NET Web表单)、.cs代码文件(C#后端逻辑)、.rdlc或.rpt报表文件(水晶报表设计)、.aspx.cs(事件处理程序)、Web.config(配置文件)等。...

    水晶报表项目运行时 去掉 输入连接数据库密码 的页面.docx

    最后,在调用水晶报表的页面中,实例化`CrystalHelper`类并调用`NoPasswd`方法。例如,在一个名为`Page_Load`或类似的事件处理程序中: ```csharp protected void Page_Load(object sender, EventArgs e) { if (!...

    ASP.net网页代码

    例如,水晶报表的设置、验证规则和Web服务的配置都可能写入此文件。通过对web.config的修改,开发者可以轻松地在整个应用程序中应用更改。 3. **Default.aspx.cs**:这是C#编写的后台代码文件,与Default.aspx相...

    外币兑换系统c# 水晶报表 四舍五入 数据查询

    【外币兑换系统c# 水晶报表 四舍五入 数据查询】是一个实用的C#编程项目,旨在提供对外币兑换业务的管理能力。这个系统具备了基础的企业级功能,是学习C#编程语言及其相关技术的优秀实例。在深入探讨这个系统的组成...

    asp.net学习积累的代码段

    Asp.Net中使用水晶报表 javascript提示类 分页 类 数据绑定 数据库方面 文件操作 验证码 ASP.NET 2.0高级控件之FileUpload控件.txt ASP.NET 程序中常用的三十三种代码.txt asp.net使用客户端验证.txt Asp.net中基于...

    ASP.NET 26个常用性能优化方法

    - **建议**: 如果应用不需要复杂的认证机制,可以通过修改Machine.config文件禁用身份验证,并在需要的Web.config文件中单独启用。 **2. 请求和响应编码** - **目的**: 根据应用需求调整编码格式以提高性能。 - **...

    《Visual C# .NET精彩编程实例集锦》第6章下

    水晶报表是强大的报表工具,可在Visual Studio中使用。此实例将指导用户通过向导创建报表,包括选择数据源、定义数据字段、布局设计和格式化输出。理解如何使用报表向导能帮助开发者快速生成复杂的报表,且与C# .NET...

    基于ASP.NET的公墓陵园管理系统源码.zip

    8. 部署和配置:ASP.NET应用程序需要在IIS(Internet Information Services)上部署,开发者需要考虑配置文件(Web.config)、应用程序池设置、数据库连接字符串等,以确保系统在生产环境中的正常运行。 9. 维护和...

    WinForms疑难解答.doc

    水晶报表** Crystal Reports是一个强大的报表工具,可以集成到WinForms应用程序中,用于设计和显示各种报表。 **39. 使用WebRequest类和WebResponse类下载或上传文件** `WebRequest`和`WebResponse`类提供了网络...

    Crystal Reports:修复了“加载报告失败”错误。

    **水晶报表:修复“加载报告失败”错误** 水晶报表(Crystal Reports)是SAP公司的一款强大的报表设计工具,广泛应用于企业级应用系统中,用于生成各类数据报告。然而,在使用过程中,用户可能会遇到“加载报告失败...

    ASP.NET3.5典型模块开发源代码

    18.3.1 创建显示数据库数据的水晶报表 228 18.3.2 创建报表的数据集 229 18.3.3 关联数据集和报表 231 18.4 自定义主从结构的水晶报表 232 18.4.1 使用带报表的网站模板 233 18.4.2 创建包含主从关系表的...

    C#编程经验技巧宝典

    4 &lt;br&gt;0008 为程序设置版本和帮助信息 4 &lt;br&gt;0009 设置Windows应用程序启动窗体 5 &lt;br&gt;0010 设置Web应用程序起始页 5 &lt;br&gt;0011 如何设置程序的出错窗口 5 &lt;br&gt;0012 如何进行程序调试 6 ...

Global site tag (gtag.js) - Google Analytics