50

我在某些用户机器上生成了这个异常(约 1 个,共 20 个):

无法加载文件或程序集“系统,版本=4.0.0.0,文化=中性,PublicKeyToken=b77a5c561934e089”或其依赖项之一。该系统找不到指定的文件。

我在网上和这个网站上发现了几个关于这个错误的引用,但没有任何帮助。

我有一个使用 WCF 连接到服务器的加载项应用程序。使用 .NET Framework 3.5 和 VS 2008 构建的加载项。

该错误仅在一个用户帐户中的一台测试机器上重现。我安装了我的应用程序,并且只能从这台机器上的一个帐户复制它,其他任何地方都可以正常工作。此外,它只能通过我为其创建插件的一个版本的主机应用程序来重现(我假设是因为它使用了不同的 .NET 框架)。

我检查了保险丝日志,看到以下内容:


Assembly manager loaded from:  C:\Windows\Microsoft.NET\Framework64\v2.0.50727\mscorwks.dll
Running under executable  C:\Program Files\SolidWorks Corp\SolidWorks\sldworks.exe
--- A detailed error log follows. 

=== Pre-bind state information ===
LOG: User = Home\User
LOG: DisplayName = System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
 (Fully-specified)
LOG: Appbase = file:///C:/Program Files/SolidWorks Corp/SolidWorks/
LOG: Initial PrivatePath = NULL
LOG: Dynamic Base = NULL
LOG: Cache Base = NULL
LOG: AppName = NULL
Calling assembly : System.Configuration, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a.

所以由于某些原因,它试图使用loader来v2.0.50727\mscorwks.dll加载Version=4.0.0.0. System.dll在构建机器上,我指的是 2.0.0.0 版本的System.dll.

4

11 回答 11

6

我遇到了同样的问题——一些用户可以从 git 中提取并且一切运行良好。有些人会拉并得到一个非常相似的异常:

无法加载文件或程序集 '...、Version=...、Culture=neutral、PublicKeyToken=...' 或其依赖项之一。该系统找不到指定的文件。

在我的特殊情况下,它是 AjaxMin,所以实际的错误看起来像这样,但细节并不重要:

无法加载文件或程序集“AjaxMin,Version=4.95.4924.12383,Culture=neutral,PublicKeyToken=21ef50ce11b5d80f”或其依赖项之一。该系统找不到指定的文件。

事实证明,这是对解决方案执行以下操作的结果:

  1. 已为解决方案打开 NuGet 包还原。

  2. 添加了一个项目,并在其中安装了一个 Nuget 包(在本例中为 AjaxMin)。

  3. 该项目已移至解决方案中的不同文件夹。

  4. Nuget 包已更新到较新的版本。

这个错误开始缓慢但肯定地开始出现在一些用户面前。

原因是解决方案级别的 packages/respositories.config 保留了旧的项目引用,现在有一个新的、第二个用于移动项目的条目。换句话说,它在重组之前有这个:

  <repository path="..\Old\packages.config" />

而这在重组之后:

  <repository path="..\Old\packages.config" />
  <repository path="..\New\packages.config" />

所以第一行现在指的是一个项目,它在磁盘上时不再是我的解决方案的一部分

启用 Nuget 包还原后,将读取两个 packages.config 文件,每个文件都指向自己的 Nuget 包和包版本列表。然而,在将 Nuget 包更新到较新版本之前,没有任何冲突。

但是,一旦更新了 Nuget 包,只有活动项目的存储库列表才会更新。NuGet Package Restore 选择仅下载一个版本的库 - 它在 repositories.config 中遇到的第一个版本,它是较旧的版本。编译器和 IDE 继续进行,就好像它选择了较新的一样。结果是一个运行时异常,说缺少 DLL。

答案显然是从该文件中删除任何引用不在您的解决方案中的项目的行。

于 2013-11-03T07:29:18.327 回答
3

我在将项目从 .net 4.5 降级到 .net 3.5 后得到了这个。

要解决我必须进入项目 - 属性 - 设置窗口并删除我的所有设置,保存项目,退出并重新启动 Visual Studio,返回项目 - 属性 - 设置窗口并重新输入我的所有设置及其默认值价值观

于 2016-05-29T18:33:24.133 回答
1

我在 Linux 下遇到了问题,我需要安装它们。我不知道哪一个真正解决了这个问题,但在那之后那个错误就消失了:

apt-get install mono-utils mono-runtime-sgen mono-runtime-common \
                mono-runtime-boehm mono-runtime-dbg mono-xbuild
于 2018-04-07T04:19:31.640 回答
1

我已经看过几次了,通常通过在 .NET Framework 上运行修复来修复它(无论应用程序尝试使用哪个版本)。

于 2019-01-25T23:24:25.053 回答
1

这对我有用。转到 Project->Propertied->Target Frawork->Change frame work like 3.5 to 4.0

于 2017-12-29T06:14:50.207 回答
0

就我而言,我可以通过在 web.config 文件中设置 Debug=true 来找到 ScriptManager 的问题

于 2015-03-07T00:11:49.860 回答
0

您正在使用.net 4?- 也许在客户端上只安装了“.net framework 4 客户端配置文件”。尝试安装完整包!! 在这里下载

于 2013-07-15T11:06:01.633 回答
0

我回答得太晚了,但它在我的情况下有效。如果您在项目中遇到此问题,请在您的 web.config 中添加以下行:

<compilation  batch="false" >

这在我的情况下有效。如果你的 web.config 中已经有编译标签,那么只添加 batch="false" 属性。

于 2015-06-01T04:40:30.130 回答
0

You can enable NuGet packages and update you dlls. so that it work. or you can update the package manually by going through the package manager in your vs if u know which version you require for your solution.

于 2015-11-17T12:25:34.343 回答
0

我刚刚更改了我的目标 .net 框架并且它有效。在我的情况下,我从 .net 4.7 更改为 .net 4。右键单击您的解决方案并选择属性选择 属性

单击应用程序>>目标框架

于 2020-12-17T18:41:13.300 回答
0

即使我遇到了一些更奇怪的事情,我也可以看到 GAC 中没有 dll 从加载 dll 的位置但是 windows > Module 显示 system.dll version=4.0.0.0 加载

于 2017-03-21T10:27:22.550 回答