Microsoft KB Archive/183480

= How to debug ISAPI DLLs in IIS 4.0, IIS 5.0, IIS 5.1, and IIS 6.0 =

Article ID: 183480

Article Last Modified on 12/3/2007

-

APPLIES TO


 * Microsoft Internet Information Services 5.1
 * Microsoft Internet Information Services 5.0
 * Microsoft Internet Information Server 4.0
 * Microsoft Internet Information Services 6.0

-



This article was previously published under Q183480



We strongly recommend that all users upgrade to Microsoft Internet Information Services (IIS) version 6.0 running on Microsoft Windows Server 2003. IIS 6.0 significantly increases Web infrastructure security. For more information about IIS security-related topics, visit the following Microsoft Web site:

http://www.microsoft.com/technet/security/prodtech/IIS.mspx



IN THIS TASK

 * INTRODUCTION
 * How to debug ISAPI DLLs in IIS 4.0, IIS 5.0, and IIS 5.1
 * How to debug an ISAPI DLL in IIS 6.0
 * REFERENCES



INTRODUCTION
This article describes one method that you can use to debug an Internet Server API (ISAPI) Extension or a filter DLL file. You must have Microsoft Visual C++ installed on the computer that is running Microsoft Internet Information Services (IIS).

back to the top



How to debug ISAPI DLLs in IIS 4.0, IIS 5.0, and IIS 5.1
 Build a debug version of the ISAPI DLL. By default, the Debug subdirectory of the project will now contain *.dll and two files with a *.pdb extension (for example, c:\MyProj\debug directory). Create a virtual root with execute permissions in the IIS Management Console, and then set its physical location to the project's Debug directory (for example, /MyProj virtual root will be mapped to c:\MyProj\Debug). Make sure that W3SVC service is running. Start it if it is not (you can use this command: net start w3svc). Start Microsoft Developer Studio. On the Build menu, click Start Debug, and then click Attach Process. Select the Show System Processes option. On a Microsoft Windows 2000-based computer, sometimes no processes will appear in the process list.

For additional information about this issue, click the following article number to view the article in the Microsoft Knowledge Base:

235434 FIX: "Attach to process" list is empty

To attach a debugger to a particular process, click the Task Manager processes tab, right-click the process that you want, and then click debug. In the list of running processes, select INETINFO. On the Project menu, click Settings, and then click the Debug tab. In the Category list, click Additional DLLs.

At this point, you should see the message that states that the DLL symbols were loaded.</li> Add your ISAPI extension or filter DLL to the list.</li> On the File menu, click Open, and then bring up the source file for the DLL. Set a breakpoint in the source code, and then submit a request to IIS from the browser (for example, http:// .dll). If the debugger beeps and refuses to set the break point, the reason for this may be a mismatch between the DLL and PDB files. Rebuild the DLL to troubleshoot this situation.</li></ol>

NOTE: If the application is configured to run out-of-proc in IIS 4.0 (or on IIS 5.0 or IIS 5.1 with an Application Protection setting of medium or high), by attaching the debugger to Inetinfo.exe, this will not break execution of an extension DLL. You must attach the debugger to the MTX.exe process (or Dllhost.exe on a Windows 2000 or Microsoft Windows XP-based system) that hosts the ISAPI DLL. Because there may be more than one MTX.exe (Dllhost.exe) process running at one time, you may have to add code to the ISAPI DLL that shows the process ID (PID) in which the DLL is loaded. After the PID is known, you can attach the debugger to the MTX (DLLHOST) with the corresponding PID. To do this, use the following code:
 * 1) define _WIN32_WINNT 0x0400

char szMessage [256]; wsprintf (szMessage, "Please attach a debugger to the process 0x%X and click OK",                                        GetCurrentProcessId); MessageBox(NULL, szMessage, "ISAPI/Filter Debug Time!",                MB_OK|MB_SERVICE_NOTIFICATION); Also, note that the Application Protection setting of medium is the default setting of IIS 5.0.
 * 1) ifdef _DEBUG
 * 1) endif

How to debug an ISAPI DLL in IIS 6
If you run IIS 6 in IIS 5 Isolation Mode, extensions and filters are loaded by Inetinfo.exe. You can use the steps in the "How to debug ISAPI DLLs in IIS 4.0, IIS 5.0, and IIS 5.1" section to debug an ISAPI Extension or a filter DLL file when IIS 6 runs in IIS 5 Isolation Mode.

If you run IIS 6 in Worker Process Isolation Mode, extensions and filters are loaded by W3wp.exe. To debug an ISAPI Extension or a filter DLL in Microsoft Visual C++ .NET, follow these steps:
 * 1) Click Start, click Run, type Cmd, and then click OK.
 * 2) At the command prompt, type net stop W3svc, and then press ENTER.
 * 3) Open your ISAPI Extension or a filter DLL project in Visual C++ .NET.
 * 4) On the Project menu, click Properties.
 * 5) Click Debugging, and then type the path to the W3wp.exe file on your computer in the Command box.
 * 6) Type -debug in the Command Arguments box, and then click OK.
 * 7) Set the breakpoints in the project.
 * 8) On the Debug menu, click Start.

Note This debugging method runs W3wp.exe in the security context of the user. This is not the security context in which W3wp.exe normally runs.

<div class="references_section">