当前位置:  开发笔记 > 编程语言 > 正文

报告查看器 - 请求SqlClientPermission类型的权限失败

如何解决《报告查看器-请求SqlClientPermission类型的权限失败》经验,为你挑选了1个好方法。

我在本地模式下使用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();

有任何想法吗?



1> Artem Koshel..:

除了CuppM的答案.ExecuteReportInCurrentAppDomain自.NET4以来,该方法已弃用,LocalReport.SetBasePermissionsForSandboxAppDomain应该使用该方法,因为ReportViewer现在始终在沙盒域中执行:

PermissionSet permissions = new PermissionSet(PermissionState.None);
permissions.AddPermission(new FileIOPermission(PermissionState.Unrestricted));
permissions.AddPermission(new SecurityPermission(SecurityPermissionFlag.Execution));
ReportViewer1.LocalReport.SetBasePermissionsForSandboxAppDomain(permissions);

详情请见此处.

推荐阅读
yzh148448
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有