views:

1005

answers:

3

Scenario: I have an ASP.NET MVC application developed in Visual Studio 2008. There is a root folder named "Content" that stores images and stylesheets. When I run locally (using Cassini) and browse my application, every resource from the "Content" directory is always downloaded. Using Firebug, I can verify that the web server returns an HTTP 200 ("ok").

Desired: I would like for Cassini to return HTTP 304 ("not modified") instead of 200. This is the behavior when running the site under IIS7.

Reasoning: The site I am working on has a large number of static resources (often as many as 40 per page). Browsing the site is very fast on IIS7, because these resources are (correctly) cached by the browser. However, browsing the site on my local machine is painfully slow.

Pages that render in under 1 second on IIS7 take over 30 seconds to render on Cassini. It's actually faster for me to upload the entire website every few minutes and test from there. (Yes, I recognize that this is perverse and crazy.)

So: how can I instruct/trick Cassini into treating the "Content" directory like IIS7 does?

+15  A: 

Are you sure the problem is caching? Because the content does get cached correctly on my machine when I run the application on Cassini.

I think the problem you're having could be Firefox's under-performance with resolving IPv6 addresses, which causes a very annoying delay on loads with addresses like http://localhost:55555.

What I did to change this behaviour was to change the network.dns.disableIPv6 preference on about:config to true on Firefox. I suggest trying that.

çağdaş
Holy crap you're a genius! I made that change and now the results are 304s, as expected. The problem *is* caching however... when network.dns.disableIPv6 is set to false, Firefox does not send the "if-match" HTTP request headers to localhost. Wierd!
Portman
:) I'm glad that did the trick. That's a really annoying problem indeed.
çağdaş
Ditto on the genius. Thanks for this answer.
womp
O. M. G. With this one answer you have magically granted me back hours in lost development time. WOW. Thank you! Never would have figure this out in a thousand years.
Dave Markle
@Dave Markle, :) You're welcome
çağdaş
Thanks for this one, been bugging me for ages..
optician
OMFG! I thought this was just because the dev web server was slow... Holy crap this is fast now. I can't believe I accepted this for so long. Yikes.
WildJoe
+2  A: 

Another option for you is to simply skip Cassini and debug under IIS. It's pretty straightforward, and won't take you ten minutes to get up and running. Browse 20 of your pages on Cassini, and you've used that time anyway ;)

One thing I've noticed isn't always in the guides, is that if you want to debug on a different address than http://localhost/ you need to manually set the host to your local IIS. This is done by adding a line in the hosts file, located at

C:\Windows\system32\drivers\etc\hosts

Open the file with notepad (you need to "Run as Administrator" in order to be able to save if you're using Windows Vista and have User Account Control turned on...) and add your host. For example, to debug under http://mysite/ you add

mysite         127.0.0.1
Tomas Lycken
I'm going to try this right now. Much better to simulate production while debugging, right?
Portman
Of course it is! =)
Tomas Lycken
Hmm... if I'm understanding this correctly, it requires you to "Publish" all of your changes. That seems like a show-stopper. If I change something in my view or stylesheet, I want to be able to save and refresh, without adding an extra step in there. Would you mind elaborating on how you have this setup on your dev box?
Portman
PS: If you want me to open a new question "How do I debug ASP.NET applications under IIS7 on Vista" I will do that so that you can get the +15 rep bump.
Portman
Reputation isn't all that matters. It's just motivation for us to help - which I apparently already did, right? But I did take a look around and couldn't find that question on SO yet, so maybe it needs to be asked... ;)
Tomas Lycken
Here you are, kind sir: http://stackoverflow.com/questions/795642/how-do-you-debug-asp-net-applications-under-iis7-on-vista
Portman
+1  A: 

I've had a similar problem in Chrome. To resolve this uncomment the IPv4 localhost line in you hosts file. Apparently these are commented by default in Windows 7.

127.0.0.1       localhost
#::1             localhost

Reference

Robert Massa