C# - .NET 4.0 - 该程序集不允许部分信任的调用者

时间:2010-11-23 20:50:54

标签: c# .net-4.0 c#-4.0 caspol .net-security

从网络共享运行时,我的应用程序抛出以下异常:

该程序集不允许部分信任的调用者。

我的应用程序引用了两个DLL文件:

  • BitFactory.Logging.dll
  • FileHelpers.dll

我不确定哪一个有问题。

  • AllowPartiallyTrustedCallersAttribute:阅读它,但我没有任何DLL文件的源代码,因此我无法将属性添加到这些DLL文件中。

  • CASPOL.EXE:使用一些变体添加了我的网络共享,例如caspol -machine -addgroup 1. -url \\netserver\netshare\* LocalIntranet似乎没有任何影响。

我之前使用的是CASPOL hack,使用.NET 3.5,然而,它现在似乎无法使用.net 4.0。任何人都可以建议我如何绕过这个“部分受信任的来电者”检查?

感谢。

1 个答案:

答案 0 :(得分:11)

.NET 4.0的安全策略有changed the default rules。您需要为此应用程序创建或修改App.config文件。

现在,在.NET 4.0中默认忽略代码访问安全性(由CASPOL配置)。如果要启用它,则需要将以下内容添加到app.config文件中:

<configuration>
   <runtime>
      <!-- enables legacy CAS policy for this process -->
      <NetFx40_LegacySecurityPolicy enabled="true" />
   </runtime>
</configuration>

您可以将.NET 4.0配置为使用LoadFrom将来自网络的代码视为完全受信任的以下配置项:

<configuration>
   <runtime>
      <!-- Treat assemblies from network locations as fully trusted. -->
      <!-- Caution: Do not point this loaded gun at your foot. -->
      <loadFromRemoteSources enabled="true" />
   </runtime>
</configuration>