59

我们收到以下程序集加载错误。程序集从本地路径“C:\Program Files\ASWorx Products\ASWorx\Bin\”加载。旧版本的二进制文件不存在问题。当我们通过电子邮件发送新的二进制文件时,就会出现问题。构建设置没有改变。我们怎样才能纠正这个问题?Win7 32位机出现问题

File name: 'file:///C:\Program Files\ASWorx Products\ASWorx\Bin\ASConnexDI.dll' ---> System.NotSupportedException: An attempt was made to load an assembly from a network location which would have caused the assembly to be sandboxed in previous versions of the .NET Framework. This release of the .NET Framework does not enable CAS policy by default, so this load may be dangerous. If this load is not intended to sandbox the assembly, please enable the loadFromRemoteSources switch. See http://go.microsoft.com/fwlink/?LinkId=155569 for more information.

   at System.Reflection.RuntimeAssembly._nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)

   at System.Reflection.RuntimeAssembly.nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)

   at System.Reflection.RuntimeAssembly.InternalLoadAssemblyName(AssemblyName assemblyRef, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection, Boolean suppressSecurityChecks)

   at System.Reflection.RuntimeAssembly.InternalLoadFrom(String assemblyFile, Evidence securityEvidence, Byte[] hashValue, AssemblyHashAlgorithm hashAlgorithm, Boolean forIntrospection, Boolean suppressSecurityChecks, StackCrawlMark& stackMark)

   at System.Reflection.Assembly.LoadFrom(String assemblyFile, Evidence securityEvidence)

   at System.Activator.CreateInstanceFromInternal(String assemblyFile, String typeName, Boolean ignoreCase, BindingFlags bindingAttr, Binder binder, Object[] args, CultureInfo culture, Object[] activationAttributes, Evidence securityInfo)

   at NeST.ICE.IOSystem.DIManager.InitializeDI()
4

4 回答 4

114

错误消息中的链接

如果应用程序是从 Web 复制的,Windows 会将其标记为 Web 应用程序,即使它驻留在本地计算机上也是如此。您可以通过更改文件属性来更改该名称,也可以使用该元素授予程序集完全信任。作为替代方案,您可以使用 UnsafeLoadFrom 方法加载操作系统已标记为已从 Web 加载的本地程序集。

尝试打开文件属性并单击“取消阻止”:

属性窗口

于 2013-03-06T04:06:29.307 回答
20

我可以使用以下链接解决此问题并将设置添加到我的配置中。

https://msdn.microsoft.com/en-us/library/dd409252(VS.100).aspx

<configuration>
   <runtime>
      <loadFromRemoteSources enabled="true"/>
   </runtime>
</configuration>
于 2016-07-19T07:10:56.990 回答
5

我不得不使用该方法

Assembly.UnsafeLoadFrom()

而不是 Assembly.LoadFrom,它解决了我的问题...在此链接中找到它:

https://msdn.microsoft.com/en-us/library/dd409252(VS.100).aspx

于 2017-09-19T05:01:00.860 回答
3

除了上面给出的答案之外,我对这个问题的解决方案。

尝试解除阻止总是导致文件似乎仍然被阻止。

因此,我创建了一个新文件夹,复制了受影响的文件并逐个文件执行解锁。令人惊讶的是,与在原始文件位置执行相同操作相比,该标志被删除了。因此,最后一步是将现在解锁的文件复制回原始位置。完毕!

于 2015-07-14T10:12:42.623 回答