- 浏览: 106014 次
- 性别:
- 来自: 长沙
最新评论
-
吉米家:
水晶报表的话,登录的确不是很好用,相比之下,帆软报表更加实用一 ...
水晶报表读取Web.config 登陆设置 -
wyqdl:
请问mysql-2.7.3-mswin32.gem这个文件从哪 ...
解决Rails2.33 与Mysql连接问题 -
wohaizai007:
你好,我是ruby初学者,你的资料没有下下来,请问怎么联系你, ...
学习ruby on rails的视频教程和电子书下载 -
allwefantasy:
zhangbo520 写道没想到出现No definition ...
Ruby on Rails 安装札记 -
zhangbo520:
没想到出现No definition for dummy_du ...
Ruby on Rails 安装札记
大家在基于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"保持一致。 当然名字是可以随便起,但必须一致
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/luchuanbo/archive/2009/05/18/4198195.aspx
发表评论
-
改变gridview选中行的背景色
2011-05-05 16:16 3133protected void gridView_OnR ... -
列隐藏或显示
2011-05-05 16:13 1178public string ls_listcolumn = & ... -
GridView通过列名取索引
2011-05-05 11:26 1670代码 public int GetColumnIndex( ... -
gridview指定列取值并修改指定列的值
2011-05-05 10:14 4104http://shanyou.cnblogs.com/arch ... -
转]asp.net 母版页使用详解
2011-05-01 09:17 1264http://jcobra.blog.163.com/bl ... -
C# .net 获取日期
2011-04-21 20:43 976DateTime.Now; 获取日期加时间 格式:2007- ... -
给下打列表框增加数据
2011-04-21 20:40 806//先定义来源 Maticsoft.BLL.ud_pub_w ... -
C#常用正则表达试
2011-04-21 18:05 1335整数或者小数:^[0-9]+\.{0,1}[0-9]{0,2} ... -
水晶报表(参数)
2011-04-13 17:31 845using CrystalDecisions.Cryst ... -
C# 从服务器上下载文件
2011-04-12 21:50 1606using System; using System.Col ... -
Excel 数据导入导出
2011-04-12 21:49 1391//导出控件Aspose.Cells 必须引用该控件 usi ... -
修改列名
2011-04-12 16:14 899GridView1.DataSource = dt; Gri ... -
加DataWindow .Net控件到Microsoft Visual Studio
2011-04-12 00:03 1118加DataWindow .Net控件到Microsoft Vi ... -
PB webserver 开发示例
2010-07-21 20:55 2826powerbuilder开发平台一直在发展,至pb9开始便已经 ... -
XP默认登录
2010-05-28 08:20 715第一种是修改注册表 这种方法比较麻烦,而且要求对注册 ... -
datawindow.net 数据库连接方
2010-04-27 09:29 1717datawindow.net 在VS2008连接 ... -
在Windows平台使用Apache2.2和Mongrel运行Ruby on Rails
2009-01-13 14:36 897在Windows平台使用Apache2.2和Mongrel运行 ... -
Eclipse下的rails开发环境建立(修正)
2009-01-13 11:55 28191.解压eclipse-platform-3.2.2-win ... -
Ruby on Rails 安装札记
2009-01-09 14:28 2078第一,安装ruby,首先从 http://www.ruby-l ... -
学习ruby on rails的视频教程和电子书下载
2009-01-08 14:36 430625个了,都不大,下载速度很快! http://www.ra ...
相关推荐
水晶报表的使用.rar水晶报表的使用.rar水晶报表的使用.rar水晶报表的使用.rar水晶报表的使用.rar水晶报表的使用.rar水晶报表的使用.rar
asp.net开发的朋友,经常用得到web.config文件的配置,所以我们特整理了中文说明。
VS.NET2005水晶报表使用方法 .doc
专业水晶报表 for Visual.Studio
第21章 水晶报表Crystal Reports.rar第21章 水晶报表Crystal Reports.rar第21章 水晶报表Crystal Reports.rar
水晶报表的WEB例子(C#)
VS2010中动态创建水晶报表的心得.大家可以根据这学到很多的知识
程序中水晶报表相关的一些.dll文件,例如CrystalDecisions.Crystalreports.Engine.dll , CrystalDecisions.Enterprise.Framwork.dll , CrystalDecisions.Enterprise.InfoStore.dll , CrystalDecisions.ReportSource....
很好的水晶报表的文档,教您一步步的创建水晶报表。
大部分制造业的产品二维码追踪 ,本源码不仅用水晶报表可以 打印二维码,而且可以制作CODE128,AN
[水晶报表9].[Crystal.Report9](ED2000.COM) 水晶报表开发工具
[精选]水晶报表技术概述.ppt
支持VS2013的水晶报表,其中主要还有WinForm的Demo,学习使用的是可以 了
.net 水晶报表实例.rar.net 水晶报表实例.rar.net 水晶报表实例.rar.net 水晶报表实例.rar
java调用水晶报表范例 myeclipse项目
Java水晶报表.pptJava水晶报表.pptJava水晶报表.ppt
用VB.NET做的,在Web页中使用水晶报表实例!!!!!!!!!!!!!!
在打开任何RPT文件,都提示”缺少P2SSQL.DLL文件,是否强行打开?...在CMD下用System32下面自带的Expand.exe解压了P2SSQL.DL_文件,然后分别放在绿色的水晶报表7目录、和C:\Windows\System32目录里面。
水晶报表
水晶报表Xtreme.mdb示例数据库英文版。 第一个例子所需要的数据库。