Próbuję zachować podstawowe zachowanie dotyczące mojej strategii buforowania: pliki powinny być buforowane i każdorazowo ponownie sprawdzane na serwerze. Chciałbym więc, aby Apache odesłał 304.
Oto okno dialogowe, które pojawia się przy każdym odświeżeniu przeglądarki:
Status Code:200 OK
Request Headers
Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
Accept-Encoding:gzip,deflate,sdch
Accept-Language:fr-FR,fr;q=0.8,en-US;q=0.6,en;q=0.4
Cache-Control:max-age=0
Connection:keep-alive
Cookie: ...
Host:...
If-Modified-Since:Tue, 14 Oct 2014 15:10:37 GMT
If-None-Match:"1461-505636af08fcd-gzip"
User-Agent:Mozilla/5.0 (X11; Linux i686) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/34.0.1847.116 Safari/537.36
Response Headers
Accept-Ranges:bytes
Cache-Control:No-cache
Connection:Keep-Alive
Content-Encoding:gzip
Content-Length:1412
Content-Type:text/html
Date:Tue, 14 Oct 2014 16:58:05 GMT
ETag:"1461-505636af08fcd-gzip"
Keep-Alive:timeout=5, max=99
Last-Modified:Tue, 14 Oct 2014 15:10:37 GMT
Server:Apache/2.4.6 (Ubuntu)
Vary:Accept-Encoding
(pochodzi z devtools chrome, bez zaznaczonej opcji Wyłącz pamięć podręczną)
Widać, że odpowiedź zawiera nagłówek Cache-Control: No-cache Header oraz że nagłówek If-Modified-Since pasuje do ostatniej modyfikacji. ETag również pasuje.
Czy w takim przypadku Apache nie powinien wysłać 304?
EDYTOWAĆ
Wyłączanie ETagów w apache za pomocą
Header unset ETag
sprawia, że zachowanie buforowania jest bardziej przewidywalne ...
Cache-Control:max-age=0
wyłączyłem pamięć podręczną, więc widziszCache-Control:No-cache
odpowiedź.