Убедите Firefox отправить заголовок If-Modified-Since через HTTPS - PullRequest
14 голосов
/ 19 августа 2008

Как я могу убедить Firefox (3.0.1, если это имеет значение) отправить заголовок If-Modified-Since в запросе HTTPS? Он отправляет заголовок, если запрос использует простой HTTP и мой сервер покорно его выполняет. Но когда я запрашиваю тот же ресурс с того же сервера, используя вместо этого HTTPS (т. Е. Просто меняя http: // в URL-адресе на https://), тогда Firefox вообще не отправляет заголовок If-Modified-Since. Это обязательное поведение по спецификации SSL или что-то?

Вот несколько примеров пар запросов и ответов HTTP и HTTPS, полученных с использованием расширения Firefox заголовков Live HTTP, с некоторыми отличиями в жирном шрифте:

HTTP-запрос / ответ:

http://myserver.com:30000/scripts/site.js

GET /scripts/site.js HTTP/1.1
Host: myserver.com:30000
User-Agent: Mozilla/5.0 (...) Gecko/2008070206 Firefox/3.0.1
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-us,en;q=0.5
Accept-Encoding: gzip,deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-Alive: 300
Connection: keep-alive
<b>If-Modified-Since: Tue, 19 Aug 2008 15:57:30 GMT
If-None-Match: "a0501d1-300a-454d22526ae80"-gzip
Cache-Control: max-age=0</b>

HTTP/1.x 304 Not Modified
Date: Tue, 19 Aug 2008 15:59:23 GMT
Server: Apache/2.2.8 (Unix) mod_ssl/2.2.8 OpenSSL/0.9.8
Connection: Keep-Alive
Keep-Alive: timeout=5, max=99
Etag: "a0501d1-300a-454d22526ae80"-gzip

HTTPS-запрос / ответ:

https://myserver.com:30001/scripts/site.js

GET /scripts/site.js HTTP/1.1
Host: myserver.com:30001
User-Agent: Mozilla/5.0 (...) Gecko/2008070206 Firefox/3.0.1
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-us,en;q=0.5
Accept-Encoding: gzip,deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-Alive: 300
Connection: keep-alive

HTTP/1.x 200 OK
Date: Tue, 19 Aug 2008 16:00:14 GMT
Server: Apache/2.2.8 (Unix) mod_ssl/2.2.8 OpenSSL/0.9.8
Last-Modified: Tue, 19 Aug 2008 15:57:30 GMT
Etag: "a0501d1-300a-454d22526ae80"-gzip
Accept-Ranges: bytes
Content-Encoding: gzip
Content-Length: 3766
Keep-Alive: timeout=5, max=100
Connection: Keep-Alive
Content-Type: text/javascript

ОБНОВЛЕНИЕ: Установив browser.cache.disk_cache_ssl в true, добились цели (что странно, потому что, как указывает Николай, все еще есть кэш памяти). Добавление заголовка «Cache-control: public» к ответу также работало. Спасибо!

Ответы [ 2 ]

14 голосов
/ 19 августа 2008

HTTPS-запросы не кэшируются, поэтому отправка If-Modified-Since не имеет никакого смысла. Не кэширование является мерой безопасности.

Не кеширование на диске является предупреждением безопасности, но, похоже, оно действительно влияет на поведение If-Modified-Since (просмотр кода).

Попробуйте установить настройку Firefox (в about: config) browser.cache.disk_cache_ssl на true . Если это поможет, попробуйте отправить в ответ заголовок Cache-Control: public .


ОБНОВЛЕНИЕ: Поведение Firefox изменено для Gecko 2.0 (Firefox 4) - содержимое HTTPS теперь кэшируется.

2 голосов
/ 19 августа 2008

HTTPS-запросы не кэшируются, поэтому отправка If-Modified-Since не имеет никакого смысла. Не кэширование является мерой безопасности.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...