大家在基于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++) 相关文章: