We're migrating an existing website from IIS6 to IIS7, but are experiencing some difficulty in setting up the 404 error page. Our 404-errorpage works like this:
- A custom ASP-page checks the URL against a short list of 'special' URLs (e.g. http://example.com/limited-offers).
- If the URL is known, it redirects to the actual URL of that page.
- Otherwise the visitor is redirected to a static errorpage with a 404-statuscode.
With IIS6 this worked as advertised, but with IIS7 some things have changed. IIS7 will always display the configured errorpage when it encounters a statuscode for which an errorpage is defined. In case of our static errorpage with 404-statuscode, this means that IIS7 will execute the custom ASP-page again. This leads to infinite redirection.
We've discovered that this behavior can be circumvented by adding a setting in Web.Config
<system.webServer>
<httpErrors existingResponse="PassThrough" />
</system.webServer>
However, after adding this our custom ASP-page refuses to redirect. After checking with Fiddler it seems that IIS7 forces the 404 statuscode, overwriting our 302 redirect.
Can anyone recommend another approach to solve our problem?
I successfully use a similar setup which I migrated from IIS 6 to IIS 7.
My web.config has the following section;
<system.webServer>
<httpErrors errorMode="Custom">
<remove statusCode="500" subStatusCode="-1" />
<remove statusCode="404" subStatusCode="-1" />
<error statusCode="404" prefixLanguageFilePath="" path="/302page.asp" responseMode="ExecuteURL" />
<error statusCode="500" prefixLanguageFilePath="" path="/500page.asp" responseMode="ExecuteURL" />
<error statusCode="500" subStatusCode="100" path="/500page.asp" responseMode="ExecuteURL" />
</httpErrors>
<system.webServer>
I configured this on the relevant site via IIS Manager but you could do it via web.config file if easier for you.
You can add conditional header depending on whether should be 301, 302 or 404.
404;
Response.Status = "404 Not Found"
Response.AddHeader "Location", pagename
302 (temporary re-direct);
Response.Status="301 Object Moved"
Response.AddHeader "Location", pagename
301 (permanent re-direct);
Response.Status="301 Moved Permanently"
Response.AddHeader "Location", pagename
IIS site's application pool uses Integrated pipeline-mode. And attached are settings for debugging section for site.
I encountered a similar scenario for a client the other week. The solution was to configure your <httpErrors>
as follows:
<httpErrors errorMode="Custom" existingResponse="Auto">
<remove statusCode="404" subStatusCode="-1" />
<error statusCode="404"
prefixLanguageFilePath=""
path="/404.asp"
responseMode="ExecuteURL" />
<remove statusCode="500" subStatusCode="100" />
<error statusCode="500"
subStatusCode="100"
prefixLanguageFilePath=""
path="/500-100.asp"
responseMode="ExecuteURL" />
</httpErrors>
This works with Cactushop (written in Classic ASP) which has "friendly" urls and where they use the 404 handler page to parse the url and render products or list categories of products and so on.
Alternatively you could look at using the IIS addon module: URLRewrite. This will allow you to set up custom SEO friendly URL's. You might find this something you want to look at to improve your application going forward rather than as a fix for your existing issue as may require some time to learn.
There's some excellent articles, video tutorials and info on how to use this tool.