如何确定.NET应用程序的依赖项?Dependency Walker是否适用于托管应用程序?我已经下载了最新的并尝试过分析应用程序,但它只是在没有太多解释的情况下退出.如果它不能与.NET一起使用,那么是否有其他工具可以帮助我调试运行时DLL加载问题?
依赖walker适用于正常的win32二进制文件.所有.NET dll和exe都有一个小的存根标题部分,使它们看起来像普通的二进制文件,但它基本上都说是"加载CLR" - 所以这就是依赖性walker会告诉你的.
要查看.NET应用程序实际依赖的内容,您可以使用Red Gate 非常出色的.NET反射器.(编辑:请注意,.NET Reflector现在是付费产品.ILSpy是免费的,开源的,非常相似.)
将DLL加载到其中,右键单击并选择"Analyze" - 然后您将看到"Depends On"项目,该项目将显示所需的所有其他dll(以及这些dll中的方法).
它有时会变得更棘手,因为你的应用程序依赖于X dll,并且存在X dll,但无论出于何种原因,无法在运行时加载或定位.
为了解决这些问题,Microsoft有一个程序集绑定日志查看器,它可以显示运行时发生的情况
我发现小型实用程序AsmSpy是解决加载程序集问题的宝贵工具.它列出了受管装配的所有装配参考,包括装配版本.
在.dll
具有以下参数的目录中的命令提示符中运行它:
asmspy . all
使用Chocolatey快速安装:
choco install asmspy
在ILDASM中打开程序集文件,然后在MANIFEST中查看@assembly extern
要浏览.NET代码依赖项,可以使用NDepend工具的功能.该工具提出:
一个依赖图
一个相关矩阵,
并且还可以编辑(或生成)一些C#LINQ查询以浏览依赖项.
例如,此类查询可能如下所示:
from m in Methods let depth = m.DepthOfIsUsing("NHibernate.NHibernateUtil.Entity(Type)") where depth >= 0 && m.IsUsing("System.IDisposable") orderby depth select new { m, depth }
它的结果如下:(注意代码度量深度,1表示直接调用者,2表示直接调用者的调用者...)(另请注意导出到图形按钮以将查询结果导出到调用图)
依赖关系图如下所示:
依赖矩阵如下所示:
依赖矩阵事实上不如图形直观,但它更适合浏览复杂的代码部分,如:
免责声明:我为NDepend工作
您无需下载和安装共享软件应用程序或工具.您可以使用.NET从程序执行Assembly.GetReferencedAssemblies()
Assembly.LoadFile(@"app").GetReferencedAssemblies()
如果您使用的是Mono工具链,则可以将该monodis
实用程序与--assemblyref
参数一起使用,以列出.NET程序集的依赖关系.这将适用于文件.exe
和.dll
文件.
monodis --assemblyref somefile.exe
$ monodis --assemblyref monop.exe AssemblyRef Table 1: Version=4.0.0.0 Name=System Flags=0x00000000 Public Key: 0x00000000: B7 7A 5C 56 19 34 E0 89 2: Version=4.0.0.0 Name=mscorlib Flags=0x00000000 Public Key: 0x00000000: B7 7A 5C 56 19 34 E0 89
$ monodis --assemblyref Mono.CSharp.dll AssemblyRef Table 1: Version=4.0.0.0 Name=mscorlib Flags=0x00000000 Public Key: 0x00000000: B7 7A 5C 56 19 34 E0 89 2: Version=4.0.0.0 Name=System.Core Flags=0x00000000 Public Key: 0x00000000: B7 7A 5C 56 19 34 E0 89 3: Version=4.0.0.0 Name=System Flags=0x00000000 Public Key: 0x00000000: B7 7A 5C 56 19 34 E0 89 4: Version=4.0.0.0 Name=System.Xml Flags=0x00000000 Public Key: 0x00000000: B7 7A 5C 56 19 34 E0 89
启用程序集绑定日志记录将HKLM\Software\Microsoft\Fusion中的注册表值EnableLog设置为1.请注意,必须重新启动应用程序(使用iisreset)才能使更改生效.
提示:请记住在完成后关闭融合日志记录,因为打开它会导致性能下降.
有趣的是,我遇到了类似的问题,没有找到合适的东西,并且意识到好老的Dependency Walker,所以最后我自己写了一个。
这专门涉及.NET,它将递归显示程序集所引用的内容(和丢失的内容)。它还将显示本机库依赖性。
它是免费的(供个人使用),有兴趣的人可以在这里找到:www.netdepends.com
欢迎反馈。