
当我与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.
总结以上是内存溢出为你收集整理的c# – 报告查看器 – 请求SqlClientPermission类型的权限失败全部内容,希望文章能够帮你解决c# – 报告查看器 – 请求SqlClientPermission类型的权限失败所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)