彻底解决 CrystalReports 登录失败问题

目录:
一、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:水晶报表中的数据库登录问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Crystal Reports是一款强大的报表设计和生成工具,它是由SAP公司开发的。这个控件可以与各种数据库进行集成,如Oracle、SQL Server、MySQL等。借助Crystal Reports,用户可以轻松地创建各种类型的报表,包括表格报表、图形报表和交叉报表等。该控件提供了丰富的数据处理和分析功能,使用户能够对数据进行排序、计算、筛选和汇总等操作。 使用Crystal Reports控件,用户可以通过简单的拖放操作,将数据字段添加到报表中,并按照自己的需求进行布局和格式化。用户可以设置报表的标题、页眉和页脚,自定义报表的样式和风格。此外,Crystal Reports还支持多语言功能,用户可以根据需要将报表翻译成不同的语言。 Crystal Reports还提供了灵活的参数选择功能,可以让用户根据不同的条件和需求生成不同的报表。用户可以设置参数,如日期范围、地区等,然后生成相应的报表。 此外,Crystal Reports还支持导出报表为不同的格式,如PDF、Excel、Word等。用户可以将报表保存为文件,或者通过电子邮件或打印等方式分享给其他人。 总的来说,Crystal Reports控件是一款功能强大、易于使用的报表生成工具。它可以帮助用户快速、准确地创建各种类型的报表,并对数据进行处理和分析。无论是个人用户还是企业用户,都可以从Crystal Reports中受益。 ### 回答2: Crystal Reports 控件是一种功能强大的报表生成工具,可以用于创建和定制各种类型的报表。它提供了丰富的功能和灵活的设计工具,方便用户根据需求进行报表设计和数据分析。 首先,Crystal Reports 控件可以连接到各种数据源,包括关系型数据库、Excel文件、文本文件等,使用户能够方便地从不同数据源中提取数据用于报表生成。同时,它还支持多种数据源的联合查询,可以将不同数据源的数据进行关联,生成更加综合和全面的报表。 其次,Crystal Reports 控件具有丰富的报表设计工具,包括报表模板、布局设计、数据字段选择等功能。用户可以根据需要自定义报表的样式、格式和布局,还可以通过添加图表、图像和其他视觉元素来增强报表的可视化效果。 此外,Crystal Reports 控件还支持数据汇总、排序、筛选和分组等功能,方便用户对报表数据进行整理和统计。用户还可以通过添加参数、公式和条件语句等来对报表数据进行更加灵活的处理和分析。 最后,Crystal Reports 控件还提供了多种输出选项,包括打印、导出为PDF、Excel、Word等格式,使用户能够方便地共享和分发报表。 综上所述,Crystal Reports 控件是一款功能强大、灵活易用的报表生成工具,可以帮助用户方便地创建、设计和分析各种类型的报表,满足企业和个人对于报表的需求。它的丰富功能和可定制性使其成为许多公司和组织进行数据分析和决策支持的重要工具。 ### 回答3: Crystal Reports控件是一款功能强大的报表设计和生成工具。它允许用户创建、定制和生成各种复杂的报表,用于分析和展示数据。 Crystal Reports控件具有丰富的功能与灵活的设计选项。用户可以通过简单的拖放操作将数据源与报表模板关联,然后进行布局、格式化和计算字段等操作。还可以使用各种图表、图形和计算字段等功能来使报表更加直观生动。 该控件支持多种数据源,包括关系数据库、文本文件、XML文件等。用户可以根据需要连接到各种数据源,然后使用SQL查询或存储过程来获取数据。Crystal Reports还提供了数据连接和筛选、数据聚合和汇总等功能,以满足用户不同的数据分析需求。 此外,Crystal Reports控件还提供了强大的报表导出和分享功能。用户可以将报表导出为PDF、Excel、Word等格式,方便与他人共享或存档。同时,还可以将报表作为纯HTML或动态网页嵌入到网站中,实现在线报表的展示和查询。 总之,Crystal Reports控件是一款功能强大、灵活易用的报表设计和生成工具。它能够帮助用户快速创建各种复杂的报表,并提供了丰富的数据分析和展示功能,满足用户不同的报表需求。无论是个人用户还是企业用户,都可以借助Crystal Reports控件轻松完成报表设计与生成的任务。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值