分享
 
 
 

水晶报表发生“登陆失败”异常,处理办法

王朝other·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

大家在基于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"保持一致。 当然名字是可以随便起,但必须一致

*******************************************************************

转自 www.chinaspx.com

作者:ydmwy

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有