25
votes

What is the best way to get hosting of an ASP.NET MVC application to work on IIS 5 (6 or 7). When I tried to publish my ASP.NET MVC application, all I seemed to get is 404 errors. I've done a bit of googleing and have found a couple of solutions, but neither seem super elegant, and I worry if they will be unusable once I come to use a shared hosting environment for the application.

Solution 1

  1. Right-click your application virtual directory on inetmgr.exe.
  2. Properties->Virtual Directory Tab-> Configuration.
  3. Add a new mapping extension. The extension should be .*, which will be mapped to the Executable C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\aspnet_isapi.dll, or the appropriate location on your computer (you can simply copy this from the mapping for .aspx files). On the mapping uncheck "check that file exists".
  4. 3 X OK and you're good to go.
  5. If you want, you can apply this setting to all your web sites. In step1, click on the "Default Web Site" node instead of your own virtual directory, and in step 2 go to the "Home Directory" tab. The rest is the same.

It seems a tad hacky to route everything through ASP.NET.

Solutions 2

Edit the MVC routing to contain .mvc in the URL and then follow the steps in solution 1 based around this extension. Edit: The original image link was lost, but here it is from Google's Cache:

alt text

5
Solutions 2 does not compile, System.Web.Routing.Route does not contain a constructore that takes '0' arguments.Maslow

5 Answers

13
votes

Answer is here

If *.mvc extension is not registered to the hosting , it will give 404 exception. The working way of hosting MVC apps in that case is to modify global.asax routing caluse in the following way.

routes.Add(new Route("{controller}.mvc.aspx/{action}", new MvcRouteHandler()) { Defaults = new RouteValueDictionary (new{ controller = "YourController"} ) });

In this way all your controller request will end up in *.mvc.aspx, which is recognized by your hosting. And as the MVC dlls are copied into your local bin , no special setttings need to be done for it.

8
votes

I think either way you'll have to do Solution 1.

Consider the HTTP Request pipeline.

  1. A request comes into IIS.
  2. IIS checks port/host header to see if it has a web site set up to capture requests for that host header/port.
  3. IIS investigates the file extension of the request (.php, .asp, .aspx) and hands it off to an ISAPI that can handle that type of request.

Only at this point does ASP.NET (or a PHP runtime) kick in. If IIS does't have that mapping then it'll never hand off the request to the ASP.NET runtime and the request will never reach your code. That's why you need that glob (*) mapping to the ASP.NET ISAPI.

ASP.NET MVC framework urls often end with no file extension at all. If you want these requests to get handled by ASP.NET (or some other runtime) you have to map all requests regardless of the file extension to that ISAPI (ie. aspnet_isapi.dll).

This is often also done for HttpHandlers that need to serve off media like .jpg, .gif. For the handler to be hit it needs to get mapped to your code even though .jpg isn't a "normal" ASP.NET file extension.

HTH,
Tyler

3
votes

Run: C:\WINDOWS\Microsoft.NET\Framework\v4.0.30319\aspnet_isapi.dll -i

This will reset IIS registry settings for aspnet user.

Create the virtual directory: 1. Right click on the directory you want to convert

  • select Properties
    1. under Directory, select Create.
    2. under Configuration, select Add.
    3. for Executable insert:

C:\WINDOWS\Microsoft.NET\Framework\v4.0.30319\aspnet_isapi.dll

for Extension insert: .*

  • uncheck “Check that file exists”

  • under Documents add entry point file, ie: Default.htm, index.htm, Global.asax

  • under Directory Settings

    1. select Edit...
    2. select Anonymous access
    3. uncheck Allow IIS to control password
    4. uncheck Basic authentication
    5. uncheck Integrated Windows authentication
    6. under ASP.NET, make sure version = v4.0.30319

TAKE NOTE of User Name ie: IUSR_AVSJ82S

Set sharing permission of physical directory:

  • In windows explorer, go to the physical directory that was converted to a virtual directory. Right click the directory name
  • select properties
  • under security tab, select Add
  • enter the IIS User name ie: IUSR_AVSJ82S click check name.
  • click OK
  • set permissions to Read and Write.
1
votes

FYI:On server 2003 (developing an app that had to connect to the RPS), it didnt' allow me to add the extension .*, I used the alternate solution modifying the route clause, and that worked.

1
votes

Have you tried adding .aspx to the end of the controller name?

It worked for Stack Overflow question Where can I get ASP.NET MVC hosting?.