水晶报表问题

cxyPioneer 2004-07-29 11:13:47
SqlConnection con = new SqlConnection"server=localhost;database=pubs;uid=sa");
SqlCommand com = con.CreateCommand();
com.CommandText= "select * from authors";
SqlDataAdapter ad = new SqlDataAdapter();
ad.SelectCommand = com;
DataSet ds = new DataSet();
con.Open();
ad.Fill(ds,"t");
CrystalReport1 cr = new CrystalReport1();
cr.SetDataSource(ds);
cr.Refresh();
this.CrystalReportViewer1.ReportSource = cr;
我这样写了以后,它报错是CrystalDecisions.CrystalReports.Engine.LogOnException: 登录失败
报表是用向导做的,是什么问题或者给一些代码
...全文
209 11 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
fuzhan820 2004-07-30
  • 打赏
  • 举报
回复
namespace yikatong.js.Report
{
/// <summary>
/// 卡比例 的摘要说明。
/// </summary>
public class Dept_test : System.Web.UI.Page
{
protected CrystalDecisions.Web.CrystalReportViewer Rptvcust;
DataTable TermTable = new DataTable("TermTable");
protected System.Web.UI.HtmlControls.HtmlForm Form1;
protected CrystalDecisions.Web.CrystalReportViewer Rptvcust1;
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
Assembly();
}

/// <summary>
/// 生成报表
/// </summary>
/// <param name="StatSN"></param>
private void Assembly()
{
ReportDocument oRpt = new ReportDocument();
string path1,path2;
path1 = Server.MapPath("../Report_Rpt");
path2 = path1+"\\Crtcust_dept.rpt";
oRpt.Load (path2);
oRpt.SetDataSource(LoadCustomerByDept());
Rptvcust1.ReportSource = oRpt;

TextObject SName;
//RTitle=oRpt.ReportDefinition.ReportObjects["text16"] as TextObject;
SName=oRpt.ReportDefinition.ReportObjects["text19"] as TextObject;
//RTitle.Text="客户花名册";
// SName.Text="ddsf";
SName.Text="制表人:"+Session["UserName"].ToString();
}

#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
private DataTable LoadCustomerByDept()
{
CreatTable();
string dept="005";
try
{
/*
if(Request.QueryString.Count>0)
{
dept=Request.QueryString["dept"].ToString();
}
*/
decimal i2=Convert.ToDecimal(dept.Length);
BASE_CUSTOMERS customer = new BASE_CUSTOMERS();
DataSet ds =new DataSet();
customer.PROC_GETCUSTINFO_monthDS(dept,4,"111111111111111111","199910",ref ds);
for(int i=0 ;i<ds.Tables[0].Rows.Count;i++)
{
DataRow tempRow;
tempRow = TermTable.NewRow();
tempRow["dptcode"]=ds.Tables[0].Rows[i]["dptcode"].ToString();
tempRow["dptname"]=ds.Tables[0].Rows[i]["dptname"].ToString();
tempRow["dptcode_p"]=ds.Tables[0].Rows[i]["dptcode_p"].ToString();
tempRow["ACCCODE"]=ds.Tables[0].Rows[i]["ACCCODE"].ToString();
tempRow["dpname1"]=ds.Tables[0].Rows[i]["PAYMN"].ToString();
tempRow["dpname2"]=ds.Tables[0].Rows[i]["SAVMN"].ToString();
TermTable.Rows.Add(tempRow);
}

return TermTable;
}
catch(Exception ex)
{
throw ex;
}
}



#region //建临时表
private void CreatTable()
{
TermTable.Columns.Add("dptcode",Type.GetType("System.String"));
TermTable.Columns.Add("dptcode_p",Type.GetType("System.String"));
TermTable.Columns.Add("dptname",Type.GetType("System.String"));
TermTable.Columns.Add("termid",Type.GetType("System.Decimal"));
TermTable.Columns.Add("termname",Type.GetType("System.String"));
TermTable.Columns.Add("ACCCODE",Type.GetType("System.String"));
TermTable.Columns.Add("dpname1",Type.GetType("System.String"));
TermTable.Columns.Add("dpname2",Type.GetType("System.String"));
}
#endregion


}
}
letmedie 2004-07-29
  • 打赏
  • 举报
回复
to: haonanernet(好男儿) ( ) 信誉:100
你简直是太厉害了,哈哈
虽然我一直是这样用这段代码
但是我一直都不知道其中的意思
哈哈
谢了
cxyPioneer 2004-07-29
  • 打赏
  • 举报
回复
我到设置位置点击替换它没有反应吗?
nhpyliner 2004-07-29
  • 打赏
  • 举报
回复
我想有两种解决办法:
一、如 ksbsoft(ksbsoft)
二、你用向导做报表时是不是,设置的数据库连接不是LocalHost呀?比如,你的机子名是nhpy,你在设置数据库时就选择的nhpy呀?若是,请你在报表上右键,选择“数据库”-“设置位置”,点"替换"按钮把nhpy替换为localhost即可!
cxyPioneer 2004-07-29
  • 打赏
  • 举报
回复
公共语言运行库将已知的 HRESULT 转换为 .NET 异常,这使得 COM 对象能够将有意义的错误信息返回给托管客户端。HRESULT 到异常的映射也可以反方向使用,将特定的 HRESULT 返回到非托管客户端。有关映射的详细信息,请参见 HRESULT 和异常。

当运行库遇到未知的 HRESULT(没有特定对应异常的 HRESULT)时,将引发 COMException 类的一个实例。此通用异常将公开与任意异常相同的成员,并包含一个公共 ErrorCode 属性,其中包含由被调用方返回的 HRESULT。如果运行库获得错误信息(从 IErrorInfo 接口、Visual Basic 中的 Err 对象,或某些情况下从操作系统获得),则该信息将被返回到调用方。但是,如果 COM 组件开发人员没能提供错误信息,则运行库将返回 8 位的 HRESULT 替代消息字符串。获得 HRESULT 使调用方可以确定一般异常的起因。


它发生的是这个异常
haonanernet 2004-07-29
  • 打赏
  • 举报
回复
大家在基于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 .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事件中添加上面的代码:
  (注意:引用千万不要忘了!)
cxyPioneer 2004-07-29
  • 打赏
  • 举报
回复
还是没有解决,不知什么原因?
chNET 2004-07-29
  • 打赏
  • 举报
回复

see:
http://forum.justdn.org/index.php?s=da11336ae7673add45e925d8e7c7b883&showtopic=14318&st=0&#entry81715
ksbsoft 2004-07-29
  • 打赏
  • 举报
回复
using CrystalDecisions.Shared ;//负责解释TableLogOnInfo类
using CrystalDecisions.CrystalReports .Engine ;//负责解释ReportDocument类
TableLogOnInfo logOnInfo = new TableLogOnInfo ();
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;
cxyPioneer 2004-07-29
  • 打赏
  • 举报
回复
那应该怎样解决这个问题?
luckweb 2004-07-29
  • 打赏
  • 举报
回复
应该是库密码不对

62,243

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧