微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 报告查看器 – 请求SqlClientPermission类型的权限失败

我在本地模式下使用Visual Studio 2008中的ReportViewer控件,其中对象作为数据源.我的类映射到数据库中的数据表.在对象中,它根据需要加载相关对象.因此,在您尝试使用该属性之前,它会将引用保留为null,然后它会尝试自动数据库加载它.这些类使用System.Data.sqlClient命名空间.

当我与Windows窗体应用程序中的对象进行交互时,一切都按预期工作.但是,当我传递要用作报表数据源的对象并尝试自动加载相关对象时,它会失败.代码创建一个sqlConnection对象,当我在其上调用GetCommand()时,抛出以下异常:

[System.Security.SecurityException] {
"Request for the permission of type 'System.Data.sqlClient.sqlClientPermission,System.Data,Version=2.0.0.0,Culture=neutral,PublicKeyToken=b77a5c561934e089' Failed."
} System.Security.SecurityException

我已经尝试搜索错误,但显示的所有结果都是在sql Server或ASP.Net上运行的CLR程序集.我在创建sqlConnection对象之前尝试在我的代码添加以下调用(如搜索结果中所示),但它显然没有做任何事情:

System.Data.sqlClient.sqlClientPermission(System.Security.Permissions.PermissionState.Unrestricted).Assert();

有任何想法吗?

解决方法

除了CuppM的答案.
从.NET4开始,不推荐使用ExecuteReportInCurrentAppDomain方法,而应使用LocalReport.SetBasePermissionsForSandBoxAppDo,因为ReportViewer现在总是在沙盒域中执行:
PermissionSet permissions = new PermissionSet(PermissionState.None);
permissions.AddPermission(new FileIOPermission(PermissionState.Unrestricted));
permissions.AddPermission(new SecurityPermission(SecurityPermissionFlag.Execution));
ReportViewer1.LocalReport.SetBasePermissionsForSandBoxAppDomain(permissions);

查看详细信息here.

原文地址:https://www.jb51.cc/csharp/96113.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐