我刚学用水晶报表,做法是按照网上的“在ASP。NET中使用水晶报表”一文制作的。可是运行项目时系统提示 “异常详细信息: CrystalDecisions.CrystalReports.Engine.LogOnException: 登录失败。”
   请问这个该怎么办呢??我的系统是 windows2003,vs2003.net,水晶报表使用的是VS2003。NET自带的cyrstal report简体中文版。

解决方案 »

  1.   

    string sqlstr="select 0,0,0,0,0,0,0 from place_order_detail";
    TableLogOnInfo logOnInfo = new TableLogOnInfo();
    ddmx oRpt=new ddmx();//ddmx 是已经建好的水晶报表
    string connstr="Provider=MSDAORA.1;Data Source=Orcl;User Id=sa;Password=orcl";
    OleDbConnection myconnect=new OleDbConnection(connstr);
    OleDbDataAdapter myadapter = new OleDbDataAdapter(sqlstr,myconnect);
    DataSet mydataset=new DataSet();
    myadapter.Fill(mydataset);
    logOnInfo.ConnectionInfo.ServerName ="Orcl";//服务器别名
    logOnInfo.ConnectionInfo.DatabaseName ="Orcl";//数据库名
    logOnInfo.ConnectionInfo.UserID ="sa";//数据库登陆名
    logOnInfo.ConnectionInfo.Password ="sql";//数据库登陆密码
    oRpt.Database .Tables [0].ApplyLogOnInfo (logOnInfo);
    oRpt.SetDataSource(mydataset.Tables[0]);
    CrystalReportViewer1.ReportSource = oRpt除了给水晶报表指定数据集外
    哈必须给水晶报表赋予登陆信息
    以上代码运行通过 希望能给对你有所帮助
      

  2.   


    http://community.csdn.net/Expert/topic/3489/3489511.xml?temp=.3877527
    应该是同样的问题
      

  3.   

    我也是刚刚测试成功的,共享给你吧!
    using System;
    using System.Collections;
    using System.ComponentModel;
    using System.Data;
    using System.Data.SqlClient;
    using System.Drawing;
    using System.Web;
    using System.Web.SessionState;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.HtmlControls;
    using CrystalDecisions.CrystalReports.Engine;//必须引用水晶报表引擎namespace baobiao
    {
    /// <summary>
    /// WebForm1 的摘要说明。
    /// </summary>
    public class WebForm1 : System.Web.UI.Page
    {
    protected CrystalDecisions.Web.CrystalReportViewer CrystalReportViewer1;

    private void Page_Load(object sender, System.EventArgs e)
    {
    //if (!this.IsPostBack)
    //{
    LoadReport();
    //}
    }
    //装载水晶报表
    private void LoadReport()
    {
    ReportDocument rpt = new ReportDocument();
    rpt.Load(Server.MapPath("CrystalReport1.rpt"));
    rpt.SetDataSource(GetDataSource());
    this.CrystalReportViewer1.ReportSource = rpt;
    } //设置数据源
    private DataSet GetDataSource()
    {
    DataSet ds = new DataSet();
    SqlConnection cn = new SqlConnection("server=ms1;initial catalog=government(BS);User ID=sa;Pwd=sa");
    SqlDataAdapter da = new SqlDataAdapter("select * from tongji_server",cn);
    da.Fill(ds,"tongji_server");
    //下面可以设置多个数据表
    //da.SelectCommand.CommandText = "select * from zbsyjbxx";
    //da.Fill(ds,"zbsyjbxx");
    //da.SelectCommand.CommandText = "select * from tblusers";
    //da.Fill(ds,"tblusers");
    //da.SelectCommand.CommandText = "select * from tblequipments";
    //da.Fill(ds,"tblequipments");
    return ds;
    }
    #region Web 窗体设计器生成的代码
    override protected void OnInit(EventArgs e)
    {
    //
    // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
    //
    InitializeComponent();
    base.OnInit(e);
    }

    /// <summary>
    /// 设计器支持所需的方法 - 不要使用代码编辑器修改
    /// 此方法的内容。
    /// </summary>
    private void InitializeComponent()
    {    
    this.Load += new System.EventHandler(this.Page_Load); }
    #endregion
    }
    }
      

  4.   

    用crystal report 10 吧
    从来没有出现这个问题
    下载的网址在.net版里搜索一下有的
      

  5.   

    目录:
    一、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\crystalreportviewers2、水晶报表文件所在的文件夹,或者导出时的目标文件夹 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:水晶报表中的数据库登录问题。
      

  6.   

    谢谢 goody9807() 等各位提供代码,呵呵,学习!
      

  7.   

    //见下面的代码
      CrystalReport1 oRpt = new CrystalReport1();
      oRpt.SetDatabaseLogon("sa", "sa");
      CrystalReportViewer1.ReportSource = oRpt;
      CrystalReportViewer1.DisplayToolbar = false;
      CrystalReportViewer1.DataBind();