社区
C#
帖子详情
急,急c#+winform下使用水晶报表数据源使用ado.net 中的DATASET,弹出登录数据库,怎么去掉那个登录的界面?
WANGHUIZE
2009-05-04 10:59:34
c#2005+winform下使用水晶报表数据源使用ado.net 中的DATASET,弹出登录数据库,怎么去掉那个登录的界面?
我没连数据库,DATASET中的表的记录是我写代码家进去的,在开发本机不会弹出登录的界面,但安装到其他电脑上就会弹出登录的界面,谢谢大家了;
...全文
1100
28
打赏
收藏
急,急c#+winform下使用水晶报表数据源使用ado.net 中的DATASET,弹出登录数据库,怎么去掉那个登录的界面?
c#2005+winform下使用水晶报表数据源使用ado.net 中的DATASET,弹出登录数据库,怎么去掉那个登录的界面? 我没连数据库,DATASET中的表的记录是我写代码家进去的,在开发本机不会弹出登录的界面,但安装到其他电脑上就会弹出登录的界面,谢谢大家了;
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用AI写文章
28 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
shiningqx
2010-01-21
打赏
举报
回复
连其他机器的DB,做报表,也出现了这个问题~~期待答案
Java_And_NET
2009-05-25
打赏
举报
回复
第一绑定数据没有绑定上,也就是说,在你的DataSet里找不到你要绑定的报表
POWER_WONG
2009-05-05
打赏
举报
回复
最好在水晶报表设计阶段连接数据库,而且连接的时候不要用数据库的表名,而用SQL命令,这样比较灵活,而且也没有那个烦人的登录对话框。
loogfeng5
2009-05-05
打赏
举报
回复
是不是连接的数据源有密码的,去掉之前的连接,再新建个不用密码数据源进行连接.
最好用数据集绑定的方式
loogfeng5
2009-05-05
打赏
举报
回复
是不是连接的数据源有密码的,去掉之前的连接,再新建个不用密码数据源进行连接.
最好用数据集绑定的方式
WANGHUIZE
2009-05-04
打赏
举报
回复
大家还有没有办法帮我下,谢谢了
陌上花花
2009-05-04
打赏
举报
回复
学习了,帮顶。
我在深圳搬砖-Justin
2009-05-04
打赏
举报
回复
很简单 你在设置数据源的时候必须要是 ArrayList 做为数据源
参考
WANGHUIZE
2009-05-04
打赏
举报
回复
我的数据源没有连接数据库,我用DATASET 是我在客户端写代码填充进去的,大家还有没有办法帮我下,谢谢了
llsen
2009-05-04
打赏
举报
回复
参考
llsen
2009-05-04
打赏
举报
回复
这个不分winform和webform
看这篇文章
取消登陆
还有这个帖子
csdn
fengxingko
2009-05-04
打赏
举报
回复
//数据库连接字符串
protected static string strConn = "server=localhost;user id=登录名;password=py;database=你的数据库";
zzxap
2009-05-04
打赏
举报
回复
在IIS上部署水晶报表时,经常会出现水晶报表页码的工具栏图片显示不出来,或者页码弹出windows登录提示窗口。
问题的症结:是水晶报表图片无访问权限
终极解决方案:在系统部署所在IIS网站的目录下,找到aspnet_client目录,在属性窗口“目录安全性”标签的“用户验证与访问控制”设置项中,勾选“允许匿名访问”,即可解决此问题。
特别提醒:需要注意的是,不要将everyone用户设置为完全控制,或者添加很多不必要的用户权限,去解决此问题,否则将导致操作系统的安全性存在重大隐患。
zzxap
2009-05-04
打赏
举报
回复
[code=C#]
大家在基于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事件中添加上面的代码:
(注意:引用千万不要忘了!)
[/CODE]
WANGHUIZE
2009-05-04
打赏
举报
回复
阿泰,小夜小鹰 ....... 请问大家还有没有好的方法,谢谢大家的帮助
WANGHUIZE
2009-05-04
打赏
举报
回复
小夜小鹰,您好,我这项目是三层模式,客户端我是不连接数据库的,我是把数据从服务端把数据拿出来,到客户端再添加到DATASET里面,报表显示是对的,如过路径不对的话,就会弹出登录的界面弹出登录的界面,按取消 弹出登录的界面
就会关掉
WANGHUIZE
2009-05-04
打赏
举报
回复
阿泰,您好,Dataset1.xsd是在项目中建的, 在"数据库专家"中,如过在"项目数据"中添加ADO.NET数据集,就会弹出登录的界面,因此我选了"创建新连接",再点"数据库文件",这样就不会弹出登录的界面,请帮我一下,谢谢您
缥缈大木头
2009-05-04
打赏
举报
回复
1、权限设置,试试2楼的大大的方法;
2、报表上的绑定字段在DataSet上不存在,或者与DataSet的属性不匹配,导致无法正确加载,这种情况更新报表数据源或者更换报表数据源就可以解决了。
楼主再仔细调查一下吧。
阿泰
2009-05-04
打赏
举报
回复
[Quote=引用 13 楼 WANGHUIZE 的回复:]
wood001,您好,谢谢您,现在发现原因,开发时我设置数据库 ADO.NET连接是" C:\我的项目\病虫害管理\报表
数据源\ Dataset1.xsd”文件,生成安装后,装到其他电脑上找不到: C:\我的项目\病虫害管理\报表数据源\ Dataset1.xsd”文件,他只认这个路径,晕,不认安装路径, -------请问在代码里怎样改路径, 谢谢大家
[/Quote]
楼主的这个帖子才真正触及到问题的本质
但是一般我们做报表的时候,生成xsd会自动转换为强类型,这样你可以再项目中直接使用而无须关心路径的
你这个怎么用了物理路径呢?
sushou2009
2009-05-04
打赏
举报
回复
UP 1L的!收藏是必须的!
加载更多回复(8)
C#
Winform
水晶报表
实例教程
**
C#
Winform
水晶报表
实例教程** 在
C#
Winform
应用程序开发
中
,
水晶报表
(Crystal Reports)是一个强大的工具,用于创建交互式、专业级别的报表。本教程将通过一系列实例,详细讲解如何在
C#
环境下利用
水晶报表
进行...
vs.net2005
水晶报表
本文档旨在详细解释如何在VS.NET 2005
中
使用
C#
语言进行
WinForm
开发时集成和利用
水晶报表
,以及如何创建、预览和发布这些报表。 #### 一、
水晶报表
简介
水晶报表
是一款由Business Objects公司开发的报表设计工具,...
水晶报表
使用
详解
在报表设计
界面
中
,通过“
数据库
专家”窗口选择“项目数据”->“
ADO.Net
数据集”->“
DataSet
1”->“Stores”表,将表添加到报表
中
。 c. **在WebForm
中
添加CrystalReportViewer控件** 添加一个新的WebForm,然后在...
C#
Winform
销售管理系统
数据库
操作在
C#
WinForm
中
主要通过
ADO.NET
库进行。我们可以
使用
SqlConnection对象连接
数据库
,SqlCommand对象执行SQL语句,SqlDataAdapter对象用于填充
DataSet
或DataTable,从而实现数据的增删改查。此外,为了提高...
精通
c#
数据库
开发(pdg)
数据库
访问基础
ADO.NET
1.1
ADO.NET
概述 1.1.1
ADO.NET
设计目标 1.1.2
ADO.NET
结构 1.1.3
ADO.NET
示例应用程序 1.2 .NET数据提供程序 1.2.1
使用
ADO连接到
数据源
1.2.2 Command命令 1.2.3 ...
C#
111,092
社区成员
642,554
社区内容
发帖
与我相关
我的任务
C#
.NET技术 C#
复制链接
扫一扫
分享
社区描述
.NET技术 C#
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
让您成为最强悍的C#开发者
试试用AI创作助手写篇文章吧
+ 用AI写文章