Hresult 0x8007007e

Hresult 0x8007007e Average ratng: 4,3/5 4331 reviews

I have dll library with unmanaged C++ API code I need to use in my .NET 4.0 application. But every method i try to load my dll i get an error:

  1. Exception Hresult 0x8007007e
  2. Hresult 0x8007007e
  3. Hresult 0x80070002 Windows 10

How to solve HRESULT: 0x8007007E problem Last updated; Save as PDF Cause: Resolution: How to solve HRESULT: 0x8007007E problem? Symptoms: you use Visual Studio 2010; 2. You create a Visual C# / Windows Application. You add reference to a.NET assembly like C: Program Files Nuance OPCaptureSDK19 Bin64 CAPIPInvoke.dll. Kevin is a dynamic and self-motivated information technology professional, with a Thorough knowledge of all facets pertaining to network infrastructure design, implementation and administration.

Unable to load DLL ‘MyOwn.dll’: The specified module could not be found. (Exception from HRESULT: 0x8007007E)

Unable to load DLL 'PrinterSettings.dll': The specified module could not be found. (Exception from HRESULT: 0x8007007E) finally, I just built my project in Debug mode configuration and this time my cpp dll was working fine.

Hresult 0x8007007e

I have read and tried severa solutions i have found on the internet. Nothing works..

I have tried using following methods:

HresultHresult 0x8007007e

When I tried following this article and when I run this example (from the downloaded code) it runs without a problem (the dll used is in the bin/debug folder)

I have copied my dll (along with all files the it depends on into my bin folder).

I also tried this approach but got the same error:

Any suggestions?

Answers:

From what I remember on Windows the search order for a dll is:

  1. Current Directory
  2. System folder, C:windowssystem32 or c:windowsSysWOW64 (for 32-bit process on 64-bit box).
  3. Reading from the Path environment variable

In addition I’d check the dependencies of the DLL, the dependency walker provided with Visual Studio can help you out here, it can also be downloaded for free: http://www.dependencywalker.com

Answers:

You can use the dumpbin tool to find out the required DLL dependencies:

This will tell you which DLLs your DLL needs to load. Particularly look out for MSVCR*.dll. I have seen your error code occur when the correct Visual C++ Redistributable is not installed.

You can get the “Visual C++ Redistributable Packages for Visual Studio 2013” from the Microsoft website. It installs c:windowssystem32MSVCR120.dll

In the file name, 120 = 12.0 = Visual Studio 2013.

Be careful that you have the right Visual Studio version (10.0 = VS 10, 11 = VS 2012, 12.0 = VS 2013…) right architecture (x64 or x86) for your DLL’s target platform, and also you need to be careful around debug builds. The debug build of a DLL depends on MSVCR120d.dll which is a debug version of the library, which is installed with Visual Studio but not by the Redistributable Package.

Answers:

Try to enter the full-path of the dll.
If it doesn’t work, try to copy the dll into the system32 folder.

Answers:

The DLL has to be in the bin folder.

In Visual Studio, I add the dll to my project (NOT in References, but “Add existing file”). Then set the “Copy to Output Directory” Property for the dll to “Copy if newer”.

Answers:

Ensure that all dependencies of your own dll are present near the dll, or in System32.

Answers:

There is one very funny thing (and has a technical relevance) which might waste your hours so thought of sharing it here –

I created a console application project ConsoleApplication1 and a class library project ClassLibrary1.

All the code which was making the p/invoke was present in ClassLibrary1.dll. So before debugging the application from visual studio I simply copied the C++ unmanaged assembly (myUnmanagedFunctions.dll) into the bindebug directory of ClassLibrary1 project so that it can be loaded at run-time by the CLR.

I kept getting the

Unable to load DLL

error for hours. Later on I realized that all such unmanaged assemblies which are to be loaded need to be copied into the bindebug directory of the start-up project ConsoleApplication1 which is usually a win form, console or web application.

So please be cautious the Current Directory in the accepted answer actually means Current Directory of main executable from where you application process is starting. Looks like an obvious thing but might not be so at times.

Lesson Learnt – Always place the unamanaged dlls in the same directory as the start-up executable to ensure that it can be found.

Answers:

Turn on the fusion logging, see this question for lots of advice on how to do that. Debugging mixed-mode apps loading problems can be a right royal pain. The fusion logging can be a big help.

Answers:

Make sure you set the Build Platform Target to x86 or x64 so that it is compatible with your DLL – which might be compiled for a 32 bit platform.

Answers:

If the DLL and the .NET projects are in the same solution and you want to compile and run both every time, you can right click the properties of the .NET project, Build events, then add something like the following to Post-build event command line:

It’s basically a DOS line, and you can tweak based on where your DLL is being built to.

Answers:

I had the same problem when I deployed my application to test PC. The problem was development PC had msvcp110d.dll and msvcr110d.dll but not the test PC.

I added “Visual Studio C++ 11.0 DebugCRT (x86)” merge module in InstalledSheild and it worked. Hope this will be helpful for someone else.

Answers:

Setup: 32-bit Windows 7

Context: Installed a PCI-GPIB driver that I was unable to communicate through due to the aforementioned issue.

Short Answer: Reinstall the driver.

Long Answer:
I also used Dependency Walker, which identified several missing dependency modules. Immediately, I thought that it must have been a botched driver installation. I didn’t want to check and restore each missing file.

The fact that I was unable to find the uninstaller under Programs and Features of the Control Panel is another indicator of bad installation. I had to manually delete a couple of *.dll in system32 and registry keys to allow for driver re-installation.

Hresult 0x8007007e

Issue fixed.

The unexpected part was that not all dependency modules were resolved. Nevertheless, the *.dll of interest can now be referenced.

Answers:

Exception Hresult 0x8007007e

This is a ‘kludge’ but you could at least use it to sanity-test:
Try hard-coding the path to the DLL in your code

Having said that; in my case running dumpbin /DEPENDENTS as suggested by @anthony-hayward, and copying over 32-bit versions of the DLLs listed there into my working directory solved this problem for me.

Exception hresult 0x8007007e

The message is just a bit misleading, becuase it isn’t “my” dll that can’t be loaded – it’s the dependencies

Answers:

I think your unmanaged library needs a manifest.
Here is how to add it to your binary. and here is why.

Hresult 0x8007007e

In summary, several Redistributable library versions can be installed in your box but only one of them should satisfy your App, and it might not be the default, so you need to tell the system the version your library needs, that’s why the manifest.

Hresult 0x80070002 Windows 10

Tags: dll