Invoking a DLL (ISAPI extension) method from an html FORM (via action)

Posted on 2000-03-06
Medium Priority
Last Modified: 2008-03-17
two part question:


Platform: NT Server 4.0
          IIS 4
          IE 5

I copied a working ISAPI extension from Visual C++ ISAPI Programming book.  The extension worked great if the method (i.e., TestDLL.dll?Test) is invoked using anchor (<a href="http://myhost/TestDLL.dll?Test>here</a>

The method also gets invoked correctly when it is invoked via the url (i.e., typing the fully qualified url addr at the address field for IE or netscape).

However, I just can't figure out how to invoke the method using a form object (i.e., via the submit button of the html form) as such:

<form action="/scripts/TestDLL.dll?Test" method="POST" name="Testing">
    <input type="submit" name="Submit2" value="Submit">
    <input type="reset" name="Reset2" value="Reset">

I've tried numerous combinations of get and post and other troubleshooting to no avail.

The error i'm getting when i click on the submit button is (in netscape 4.7):


Your client sent a request that this server didn't understand.
Request: Test

1. how can I get the method to executing when the user clicks on the submit button?
2. if the method requires parameters, how can i pass those form parameters (as entered by the user) to the method?

Thank you

Question by:bustany
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions

Expert Comment

ID: 2590991
bustany sorry if my answer is not what you want,
but from your description it looks like the dll checks for the query string(URL).
I know of ISAPI filters doing this but not ISAPI extensions.
Is it possible in ISAPI extensions also?

Expert Comment

ID: 2592745

My understanding is that every isapi extension handles cerntain input in certain format. Some extension may accept a file, and then put the file into database. Some extension may just accept a string, and search the database and return the results to the client. I don't have your book, so I don't know exactly what testDll.dll does.

Here is my general comments:

Look in testDll.cpp (if it's in c++)
and find HttpExtensionProc(), you should see main logic there as what the program is looking for. In some cases, it looks for some predefined fields. e.g. the funciton may be looking for "FieldName1", "FieldName2". Whereas you are sending "Submit2" and "Reset2". If the program can not find the fields it is looking for, it may just return error.

One possible reason can also be your form html syntax. Some extension accepts form input using multipart format. If that's the case, you will need to add enctype="multipart/form-data" to your form.

Good luck.

Expert Comment

ID: 2599252
your first line of code was:

<form action="/scripts/TestDLL.dll?Test" method="POST" name="Testing">

replace it with:

<form action="/scripts/TestDLL.dll" method="POST" name="Testing">
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!


Expert Comment

ID: 2600903
Download ftp://ftp.wrox.com/professional/664.zip . Extract it and look in the FormMail folder.  This will put you well on your way.

Expert Comment

ID: 2614686
You need to write parse map entries for your function

Look for the line that begins with  BEGIN_PARSE_MAP

That's where you define your entry point and their arguments

In your case you probably have something like:


This means that Test takes no arguments

replace with something like:


Look up these macros in VC++ help for more information

Expert Comment

ID: 2615962
oh yeah, and don't forget to change the signature of the Test function from

void Test()


void Test(char* submit2)


Author Comment

ID: 2618142
I actually did all that as part of copying the sample code from the text.  I found out the reason for it not working was due to the fact that i "overloaded" Test, one without any
params, and one with two parms.  Once I renamed the second test, it worked.  So I guess in handling forms via an isapi, once can not overload methods!!! pretty bad on microsoft's side, i think.  

Accepted Solution

loumf earned 600 total points
ID: 2619687
The problem is not really microsoft's.  The macros become expressions with pointers to functions and C++ offers no way to resolve overloads when naming them.

Featured Post

Free Tool: SSL Checker

Scans your site and returns information about your SSL implementation and certificate. Helpful for debugging and validating your SSL configuration.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Written by John Humphreys C++ Threading and the POSIX Library This article will cover the basic information that you need to know in order to make use of the POSIX threading library available for C and C++ on UNIX and most Linux systems.   [s…
Basic understanding on "OO- Object Orientation" is needed for designing a logical solution to solve a problem. Basic OOAD is a prerequisite for a coder to ensure that they follow the basic design of OO. This would help developers to understand the b…
The viewer will learn how to use the return statement in functions in C++. The video will also teach the user how to pass data to a function and have the function return data back for further processing.
The viewer will be introduced to the technique of using vectors in C++. The video will cover how to define a vector, store values in the vector and retrieve data from the values stored in the vector.
Suggested Courses
Course of the Month12 days, 7 hours left to enroll

777 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question