Почему использование ASP.NET OutputCache продолжает возвращать 200 OK, а не 304 Not Modified? - PullRequest
6 голосов
/ 01 июня 2010

У меня есть простая страница aspx. Вот вершина этого: -

<%@ Page 
    Language="C#" 
    AutoEventWireup="true" 
    CodeFile="Foo.aspx.cs" 
    Inherits="Foo" %>
<%@ OutputCache Duration="3600" VaryByParam="none" Location="Any" %>

Теперь, каждый раз, когда я нажимаю на страницу в FireFox (либо нажимаю F5, либо нажимаю ввод в строке URL), я получаю ответ 200 OK. Вот пример ответа от FireBug: -

Заголовки запроса: -

GET /sitemap.xml HTTP/1.1
Host: localhost.foo.com.au
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.1; en-GB; rv:1.9.2) 
            Gecko/20100115 Firefox/3.6
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-au,en-gb;q=0.7,en;q=0.3
Accept-Encoding: gzip,deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-Alive: 115
Connection: keep-alive
Cookie: <snipped>
If-Modified-Since: Tue, 01 Jun 2010 07:35:17 GMT
If-None-Match: ""
Cache-Control: max-age=0

Заголовки ответа: -

HTTP/1.1 200 OK
Cache-Control: public
Content-Type: text/xml; charset=utf-8
Expires: Tue, 01 Jun 2010 08:35:17 GMT
Last-Modified: Tue, 01 Jun 2010 07:35:17 GMT
Etag: ""
Server: Microsoft-IIS/7.5
X-Powered-By: UrlRewriter.NET 2.0.0
X-AspNet-Version: 4.0.30319
Date: Tue, 01 Jun 2010 07:35:20 GMT
Content-Length: 775

Вкладка Firebug Cache: -

Last Modified   Tue Jun 01 2010 17:35:20 GMT+1000 (AUS Eastern Standard Time)
Last Fetched    Tue Jun 01 2010 17:35:20 GMT+1000 (AUS Eastern Standard Time)
Expires Tue Jun 01 2010 18:35:17 GMT+1000 (AUS Eastern Standard Time)
Data Size   775
Fetch Count 105
Device  disk

Теперь, если я попробую это в Fiddler, используя Компоновщик запросов (и без дополнительных данных), я также продолжу получать тот же самый ответ 200 OK.

Заголовки запроса: -

GET http://localhost.foo.com.au/sitemap.xml HTTP/1.1
User-Agent: Fiddler
Host: foo.com.au

Заголовки ответа: -

HTTP/1.1 200 OK
Cache-Control: public
Content-Type: text/xml; charset=utf-8
Expires: Tue, 01 Jun 2010 07:58:00 GMT
Last-Modified: Tue, 01 Jun 2010 06:58:00 GMT
ETag: ""
Server: Microsoft-IIS/7.5
X-Powered-By: UrlRewriter.NET 2.0.0
X-AspNet-Version: 4.0.30319
Date: Tue, 01 Jun 2010 06:59:16 GMT
Content-Length: 775

Похоже, он просит его кешировать, но это не так: (

Сервер является локальным хостом IIS7.5 на Win7. (как указано в данных ответа).

Кто-нибудь может увидеть, что я делаю не так?

Ответы [ 2 ]

2 голосов
/ 19 марта 2012

Я думаю, вы должны установить VaryByParam="" вместо "none", чтобы получить expected 304 (не изменяется, когда пользователь использует клавишу ввода в строке URL).

Использование "" Vary HttpHeader означает , а не , отправленное на сервер как часть заголовков запроса.

При использовании "None" Vary HttpHeader отправляется на сервер как часть заголовков запроса.

0 голосов
/ 01 июня 2010

Попробуйте запустить веб-сайт с другого компьютера, чтобы убедиться, что это не поведение вызовов локального хоста.

...