如何以编程方式检查C DLL文件和C#DLL文件以获取对调试DLLS的引用
我遇到过这个问题太多次了,需要这个是一个自动化的方法:
我有多个DLL文件,不断建立/更改多个项目使用. 我创建了一个C#应用程序,它可以检测DLL文件是否存在,如果不存在则会警告运算符并杀死程序.在这个C#应用程序中,我希望它也检查以确定它是否是“调试”版本 – 换句话说,如果它在最终用户计算机上运行它会崩溃. 现在我一直在寻找高低,找到了一些可能的解决方案,但它们都落空了. Assembly.LoadFrom(string)不适用于非托管代码.我可以用它来测试托管的DLL文件,而不是C文件. 我想我可以使用Dependency Walker或类似的程序在我的应用程序中运行给我汇编引用的数据,不幸的是,depends.exe控制台只输出到一个文件(然后我必须在每个文件中读取并解析它为我的数据(非常密集加上我必须在我的项目中包含depends.exe和DLL文件)),此外,它似乎没有输出我真正想要的数据(或至少我不能做它). 也尝试了dumpbin,但我似乎无法让它在我的机器上运行. 我还发现了一些本应给我Dependency Walker源代码的链接.不幸的是他们都死了.我不认为这是一件难以做到的事情,但无论出于何种原因,我都很难弄清楚如何实现自动化. 一些对我有帮助的源链接,但它们都没有解决非托管程序集数据的问题. > Listing Referenced Assemblies 解决方法
如果您知道所有DLL的名称(例如,因为您运行了Dependency Walker),您可以使用LoadLibrary来检查非托管DLL.
[DllImport("kernel32.dll")] static extern IntPtr LoadLibrary(string dllToLoad); [DllImport("kernel32.dll")] static extern IntPtr LoadLibraryEx(string lpFileName,IntPtr hFile,uint dwFlags); const UInt32 DONT_RESOLVE_DLL_REFERENCES = 0x00000001; const UInt32 LOAD_LIBRARY_AS_DATAFILE = 0x00000002; const UInt32 LOAD_WITH_ALTERED_SEARCH_PATH = 0x00000008; [DllImport("kernel32.dll")] static extern bool FreeLibrary(IntPtr hModule); [DllImport("kernel32.dll")] static extern UInt32 GetLastError(); void CheckUnmanagedDll(string DllName) { IntPtr hModule = LoadLibrary(DllName); if (hModule.Equals(IntPtr.Zero)) MessageBox.Show("Can't find " + DllName); FreeLibrary(hModule); } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |