无法从程序集"Not.Containing.Type.A"加载类型"A"

Zde*_*něk 6 .net c# .net-assembly

编辑:我没有提到一个重要的事情 - 加载我的程序集的应用程序实际上不在同一目录(与其他dll).在摆弄Fusion日志之后,我注意到加载的dll行为与我之前的想法不同.(是的,我应该先RTFM,对我感到羞耻)

  • C:\Test\appLoadingStuff.exe
  • C:\Lib\Acme.Application.dll
  • C:\Lib\Acme.Data.dll
  • ...

.NET正在探测应用程序库(除了GAC和东西;加载应用程序的目录是 - C:\Test\),并不关心dll存储加载的位置(其他目录).


在使用.NET框架时,我发现自己得到了一个ReflectionTypeLoadException例外:

System.TypeLoadException

无法加载一个或多个请求的类型.检索LoaderExceptions属性以获取更多信息.

无法从程序集'Acme.Data.Dao,Version = 1.1.0.4,Culture = neutral,PublicKeyToken = null'加载类型'Acme.Data.Foo'.":"Acme.Data.Foo

为简单起见,我有3个组件:

  • Acme.Application 我的主要装配
  • Acme.Data 我的数据对象(由第一个引用)
  • Acme.Data.Dao 我的数据访问对象(由第一个引用)

还有另一个应用程序,实际上加载我的主程序集.所有.dll文件都在同一目录中.

正如您所料,类型Acme.Data.Foo是生活在组装中Acme.Data.尽管如此,.NET正试图在另一个程序集中找到它Acme.Data.Dao- 它失败了,因为类型不存在.

我无法弄清楚是什么让.NET在错误的程序集中寻找特定类型.在汇编时访问类型时会立即抛出异常:

System.Reflection.RuntimeAssembly assembly = Assembly.LoadFile("C:\Lib\Acme.Application.dll")
var types = assembly.GetTypes(); // -> explodes
Run Code Online (Sandbox Code Playgroud)

当我尝试使用以下方法检查引用的程序集

assembly.GetReferencedAssemblies()
Run Code Online (Sandbox Code Playgroud)

我可以在列表中清楚地看到我想要的装配.

没有程序集重定向(据我所知,这仅影响版本).程序集的版本是正确的.

我还应该寻找什么?

Zde*_*něk 1

正如我在编辑问题中所说的那样,我错过了提及我正在尝试做的事情的非常重要的属性。我的程序集是由另一个应用程序加载的,该应用程序与加载的程序集不在同一路径中

.NET 正在探测正在运行的应用程序的目录,而不是加载的 dll 所在的目录。如果需要处理这种情况,则有必要实现事件处理程序AppDomain.AssemblyResolve来处理已加载的依赖项dll

更多阅读:

感谢参与这个问题的任何人,很抱歉我没有分享如此重要的细节(说实话,我没想到这个小细节很重要 - 现在我知道了)。