DOCUMENT:Q154466 06-MAY-2001 [visualc] TITLE :FIX: Unable to Locate URLMON.DLL on Windows NT 3.51 PRODUCT :Microsoft C Compiler PROD/VER:WINDOWS:4.0; winnt:4.2,5.0 OPER/SYS: KEYWORDS:kbole kbIE400 kbMFC kbOSWinNT351 kbVC420bug kbVC500bug kbVC600fix kbGrpDSMFCATL kbNoUpd ====================================================================== ------------------------------------------------------------------------------- The information in this article applies to: - The Microsoft Foundation Classes (MFC), used with: - Microsoft Visual C++, 32-bit Enterprise Edition, version 4.2 - Microsoft Visual C++, 32-bit Professional Edition, version 4.2 - Microsoft Visual C++, 32-bit Enterprise Edition, version 5.0 - Microsoft Visual C++, 32-bit Professional Edition, version 5.0 - Microsoft Internet Explorer (Programming) version 4.0 ------------------------------------------------------------------------------- SYMPTOMS ======== When attempting to run an application built with Visual C++ 4.2 and 5.0, an error may be reported that the Urlmon.dll cannot be found. After this error, the application aborts. This error occurs only under the following circumstances: - The operating system is Windows NT 3.51. - The executable is a debug build. - The project is statically linked to MFC library. - The project has enabled OLE functionality (directly or indirectly includes afxole.h or afxdisp.h). CAUSE ===== The Urlmon.dll is the DLL that supports the URL moniker. It is a part of the ActiveX SDK. The MFC library that ships with Visual C++ 4.2 and 5.0 uses this DLL for much of the Internet functionality added in Visual C++ 4.2. Urlmon.dll is not supported on Windows NT 3.51. Therefore, the DLL is not installed to your Windows NT 3.51 System32 directory. MFC applications that target Windows NT 3.51 cannot use the URL moniker SDK functions. However, an application that meets all of the criteria listed in the SYMPTOMS section of this article but does not use these functions will still attempt to load the DLL. Therefore, the run-time error occurs. RESOLUTION ========== To work around this problem, you must link the debug build of the application with the MFC DLL. The release build can continue to link statically to MFC. To link the debug build of the application to the MFC DLL, select Project Settings on the Build menu in Visual C++. Select Debug Project in the Settings For list, and select "Use MFC in a Shared Dll(mfc42(d).dll)" on the General Settings tab. STATUS ====== Microsoft has confirmed this to be a bug in the Microsoft products listed at the beginning of this article. This problem was corrected in Visual C++ version 6.0 for Windows. MORE INFORMATION ================ Visual C++ 4.2 and 5.0 ship the Urlmon.dll as part of the self-extracting installation files Axdist.exe and Wintdist.exe. This is covered in the \msdev\redist\redistrb.wri file. Additional query words: urlmon.dll ====================================================================== Keywords : kbole kbIE400 kbMFC kbOSWinNT351 kbVC420bug kbVC500bug kbVC600fix kbGrpDSMFCATL kbNoUpdate Technology : kbAudDeveloper kbMFC Version : WINDOWS:4.0; winnt:4.2,5.0 Issue type : kbbug Solution Type : kbfix ============================================================================= THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY. Copyright Microsoft Corporation 2001.