分享
 
 
 

彻底解决 CrystalReports 登录失败问题

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

目录:

一、Crystal Reports 9 最新补丁下载(搜集:海波.NET)

二、原因1:文件夹 NTFS 权限的问题。

三、原因2:PULL 模式,水晶报表中的数据库登录问题(非 Windows 集成身份验证)。

四、原因3:PUSH 模式设置了 TableLogOnInfo,不需要!

五、出错:部署到其它计算机,产生问题:连接失败。错误的登录参数。

六、安全之道:crystalreport 的集成认证如何与NT(2K)SERVER集成?

七、原因4:PULL 模式,水晶报表中的数据库登录问题(Windows 集成身份验证)。

---------------------------------------------------------------

问题:

CrystalReports 登录失败

LogOnException

---------------------------------------------------------------

一、Crystal Reports 9 最新补丁下载

(1)Crystal Reports 9 Database and Export Drivers Monthly Hot Fix

http://support.crystaldecisions.com/communityCS/FilesAndUpdates/cr90dbexwin_en.zip.asp?recDnlReq=Record&dnlPath=cr90dbexwin_en.zip

(2)Crystal Reports 9 Developer Files Monthly Hot Fix

http://support.crystaldecisions.com/communityCS/FilesAndUpdates/cr90devwin_en.zip.asp?recDnlReq=Record&dnlPath=cr90devwin_en.zip

(3)Crystal Reports 9.0 Main Program Files Monthly Hot Fix

http://support.crystaldecisions.com/communityCS/FilesAndUpdates/cr90mainwin_en.zip.asp?recDnlReq=Record&dnlPath=cr90mainwin_en.zip

---------------------------------------------------------------

二、原因1:文件夹 NTFS 权限的问题。

1、水晶报表 Web 查看器文件夹 NTFS 权限的问题

(1)错误提示:

“/WebApplication1”应用程序中的服务器错误。

登录失败。

说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: CrystalDecisions.CrystalReports.Engine.LogOnException: 登录失败。

(2)相关文件夹:

VS.NET Crystal Reports: C:\Program Files\Microsoft Visual Studio .NET\Crystal Reports\Viewers

Crystal Reports 9.2: C:\Program Files\Common Files\Crystal Decisions\2.0\crystalreportviewers

2、水晶报表文件所在的文件夹,或者导出时的目标文件夹 NTFS 权限的问题

(1)错误提示:

登录失败。

说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: CrystalDecisions.CrystalReports.Engine.LogOnException: 登录失败。

3、设置上述文件夹的“安全”,即 NTFS 权限:

最简单的办法是给 Everyone 用户加“完全控制”权限!

(1)为当前用户,如:Administrator,,添加“写入”权限;

(2)为用户 ASPNET、SYSTEM、匿名用户(通常为 IUSR_MACHINENAME)、经过身份验证的请求用户添加“写入”权限。

---------------------------------------------------------------

三、原因2:PULL 模式,水晶报表中的数据库登录问题。

运行时登录数据库服务器的方法(PULL 模式)

在报表的cs文件中,加上数据库连接。

1、设置 ReportDocument 的 TableLogonInfo……

Dim ReportDoc As New ReportDocument()

Dim logonInfo As New TableLogonInfo

Dim table As table

ReportDoc.Load("C:\Rpts\publish.rpt")

For Each table IN ReportDoc.DataBase.Tables

logonInfo= table.LogonInfo

with logonInfo.connectioninfo

.serverName= "Localhost"

.Databasename= "pubs"

.UserID= "sa"

.Password=""

End With

table.applyLogonInfo(logonInfo)

next table

Crviewer.reportsource = reportDoc

2、如果是多个相关的表作为报表的数据源,最好使用存储过程或者查询作为数据源。

3、将“数据库连接信息”存放在 web.config 配置文件,易维护。

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 path;

path=Server.MapPath ("cr.rpt");

oRpt.Load (path);

//从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;

DataBind();

}

---------------------------------------------------------------

四、原因3:PUSH 模式设置了 TableLogOnInfo,不需要!

因为数据源是 DataSet,不是数据库!

---------------------------------------------------------------

五、出错:部署到其它计算机,产生问题:连接失败。错误的登录参数。

在开发机(2000)上运行,一切正常;移植到生产机(2003),就报错。错误提示:连接失败。错误的登录参数。

解决方案:

部署包少了点东西:

Crystal_Database_Access2003.msm

Crystal_Database_Access2003_chs.msm

这两个合并模块包含各种连接数据源的驱动。所以少了它,就老是提示登录失败(这种提示是不是很莫名其妙?)

---------------------------------------------------------------

六、安全之道:crystalreport 的集成认证如何与NT(2K)SERVER集成??

--------------------------------------

安全三要素:

模拟,验证,授权

--------------------------------------

如果运行 ASP.NET 程序,还需要为 ASPNET 账号——运行 ASP.NET 模拟的账号,做下述设置:

1、通过 Web 访问服务器,访问者默认“模拟”的是——Internet 来宾帐号,账号名:IUSR_计算机名;

2、“IUSR_计算机名”账号要访问 SQL SERVER,必须为该帐号建立“登录”(验证也!);

3、并授予“服务器角色”和“数据库访问许可”、“数据库角色”(授权也)!

--------------------------------------

参考:

1、匿名访问 Web 所模拟的账号

账号名:IUSR_计算机名

全名:Internet 来宾帐号

描述:匿名访问 Internet 信息服务的内置帐号

2、运行 ASP.NET 模拟的账号

账号名:ASPNET

全名:aspnet_wp account

描述:运行 ASP.NET 工作进程的账号

---------------------------------------------------------------

七、原因4:PULL 模式,水晶报表中的数据库登录问题(Windows 集成身份验证)。

1、错误提示:

“/MyWebApp”应用程序中的服务器错误。

用户 'PYPC101\ASPNET' 登录失败。

2、问题分析:

设计水晶报表时,在“数据库专家”的“连接信息”里使用了“集成安全”,即 Windows 集成身份验证。

3、解决方案:

要为 ASPNET 账号增加数据库登录和访问权限……

但这样不太适用,设计时最好使用数据库服务器的身份验证,用服务器的账号登录,比如:sa!

4、参考:三、原因2:水晶报表中的数据库登录问题。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
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- 王朝網路 版權所有