C#调用非托管DLL时遇到“找不到指定的模块”问题解决方法

最近开发的C# 后台服务程序,加载公司老的C++开发的DLL。

加载方式如下:

[DllImport("SpeedData.dll")]

public static extern int GetISpeed(out ISpeed pISpeed);

在本机环境运行正常,但是放到服务器上执行就会出现错误:

Unable to load DLL 'SpeedData.dll': 找不到指定的模块。 (Exception from HRESULT: 0x8007007E)

网上发现很多人都遇到了类似的问题,这里把我解决的方法和过程分享一下。

为了验证问题,又写了一个Winform程序来使用相同的方法调用。执行发现没有问题,DLL可以正常加载并运行。说明环境是正常的。

那为什么会提示找不到指定的模块?用Depends.exe看了,依赖项都有。

是在没办法,根据网上的经验,下载了ProcessMonitor,查看程序加载的文件。果然找到了问题。

我加载的Dll是VS2010开发的,需要VS2010的C++的库。而我的这台机器上并没有安装这个库,而是将Dll直接复制到这台电脑的D盘某目录下的,在user的path中增加了引用路径。当执行exe的时候,是当前用户运行的,所以能够搜索的依赖的DLL。当执行服务时,使用的是LOCAL SERVICE账号,在System的path中是没有这个引用路径的,所以找不到DLL。报错找不到指定的模块。

重新梳理了一下引用路径。这个问题彻底的解决了。

大家遇到这个错误的时候,最好的办法就是用ProcessMonitor,看一下引用的文件是否能够找到,缺少哪个补哪个就好。