我遇到过这个问题太多次了,需要这个是一个自动化的方法:
我有多个DLL文件,不断建立/更改多个项目使用.
我创建了一个C#应用程序,它可以检测DLL文件是否存在,如果不存在则会警告运算符并杀死程序.在这个C#应用程序中,我希望它也检查以确定它是否是“调试”版本 – 换句话说,如果它在最终用户计算机上运行它会崩溃.
现在我一直在寻找高低,找到了一些可能的解决方案,但它们都落空了.
Assembly.LoadFrom(string)不适用于非托管代码.我可以用它来测试托管的DLL文件,而不是C文件.
我想我可以使用Dependency Walker或类似的程序在我的应用程序中运行给我汇编引用的数据,不幸的是,depends.exe控制台只输出到一个文件(然后我必须在每个文件中读取并解析它为我的数据(非常密集加上我必须在我的项目中包含depends.exe和DLL文件)),此外,它似乎没有输出我真正想要的数据(或至少我不能做它).
也尝试了dumpbin,但我似乎无法让它在我的机器上运行.
我还发现了一些本应给我Dependency Walker源代码的链接.不幸的是他们都死了.我不认为这是一件难以做到的事情,但无论出于何种原因,我都很难弄清楚如何实现自动化.
一些对我有帮助的源链接,但它们都没有解决非托管程序集数据的问题.
> Listing Referenced Assemblies
> How to automate integration testing?(堆栈溢出)
> Determining if a .NET Assembly is compiled debug or not
> How to tell if a .NET Assembly is debug or release
> Programmatically detecting Release/Debug mode (.NET)(堆栈溢出)
> How do I detect the DLLs required by an application?(堆栈溢出)
> How to Programmatically Detect if an Assembly is Compiled in Debug or Release mode
最佳答案 如果您知道所有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);
}