Я только что начал хранить изображения, загруженные пользователями, на Amazon S3. Это довольно приятно, потому что позаботилось о моей проблеме с хранением. Тем не менее, я борюсь, когда дело доходит до того, чтобы браузер кэшировал изображения.
Я использую django-storages. В своих документах они указывают, что вы можете поместить что-то в заголовок запроса для изображения, установив переменную AWS_HEADER в своих настройках. Я так делаю, а результата нет.
Обычно, когда приложение запрашивает изображения, я получаю 200 КАЖДЫЙ РАЗ. ARG... когда я перехожу в браузере прямо к изображению (скопируйте и вставьте ссылку в новое окно), я получаю 200, а затем 304 каждый раз после этого.
Это очень расстраивает, потому что каждый раз загружает изображение заново. На некоторых страницах есть до 25 маленьких миниатюр, и каждый раз при перезагрузке страницы все загружается заново.
Я обслуживаю свои статические файлы с помощью статических файлов djangos, и они работают правильно. Я получаю 200, затем 304 после кэширования файла.
вот мои настройки AWS в настройках.py
DEFAULT_FILE_STORAGE = 'storages.backends.s3boto.S3BotoStorage'
AWS_ACCESS_KEY_ID = '***'
AWS_SECRET_ACCESS_KEY = '***'
AWS_STORAGE_BUCKET_NAME = 'foobar_uploads'
AWS_HEADERS = {
'Expires': 'Thu, 15 Apr 2020 20:00:00 GMT',
'Cache-Control': 'max-age=86400',
}
AWS_CALLING_FORMAT = CallingFormat.SUBDOMAIN
вот заголовки запроса и ответа, когда приложение запрашивает изображение: (я заменил то, что я считаю конфиденциальной информацией, на '*')
##request##
GET /user_uploads/*****/2012/3/17/14/46/thumb_a_28_DSC_0472.jpg?Signature=FVR6T%2BXFwHMmdQ9K3n7Ppp7QxoY%3D&Expires=1332023525&AWSAccessKeyId=***** HTTP/1.1
Host: *****_user_uploads_sandbox.s3.amazonaws.com
Connection: keep-alive
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_7_3) AppleWebKit/535.11 (KHTML, like Gecko) Chrome/17.0.963.79 Safari/535.11
Accept: */*
Referer: http://localhost:8000/m/my-photos/
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-US,en;q=0.8
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3
##response##
HTTP/1.1 200 OK
x-amz-id-2: Hn3S+3gmeLHIjKCpz+2ocE6aPsLCVHh56jJYTsPHwxU98y89x+9X1Ml202evBUHT
x-amz-request-id: 528CEB880CA89AD3
Date: Sat, 17 Mar 2012 21:32:06 GMT
Cache-Control: max-age=86400
Expires: Thu, 15 Apr 2020 20:00:00 GMT
Last-Modified: Sat, 17 Mar 2012 20:46:29 GMT
ETag: "a3bc70e0c3fc0deb974edf95668e9030"
Accept-Ranges: bytes
Content-Type: image/jpeg
Content-Length: 8608
Server: AmazonS3
вот запрос/ заголовки ответа, когда я вручную запрашиваю изображение, копируя и вставляя ссылку на изображение:
##request##
GET /user_uploads/*****/2012/3/17/14/46/thumb_a_28_DSC_0472.jpg?Signature=FVR6T%2BXFwHMmdQ9K3n7Ppp7QxoY%3D&Expires=1332023525&AWSAccessKeyId=***** HTTP/1.1
Host: porlio_user_uploads_sandbox.s3.amazonaws.com
Connection: keep-alive
Cache-Control: max-age=0
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_7_3) AppleWebKit/535.11 (KHTML, like Gecko) Chrome/17.0.963.79 Safari/535.11
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-US,en;q=0.8
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3
If-None-Match: "a3bc70e0c3fc0deb974edf95668e9030"
If-Modified-Since: Sat, 17 Mar 2012 20:46:29 GMT
##response##
HTTP/1.1 304 Not Modified
x-amz-id-2: FZH0imrbNxziMznhl5zAoo38CaM7Z+TFnd8R6HtTYB3eTmVpCih+1IniKaliRo18
x-amz-request-id: 3CACF77FBB39D088
Date: Sat, 17 Mar 2012 21:33:22 GMT
Last-Modified: Sat, 17 Mar 2012 20:46:29 GMT
ETag: "a3bc70e0c3fc0deb974edf95668e9030"
Server: AmazonS3
Я вижу, что есть несколько различий, таких как «If-None-Match:» или «If-Modified-Since:». Я думаю, что если бы я их поставил, то все должно было бы работать так, как я хотел бы.
Есть ли простой способ сделать это?
Спасибо за любую помощь!
РЕДАКТИРОВАТЬ 1: Я прочитал эту статью и не смог ее правильно перевести.. http://coder.cl/2012/01/django-and-amazon-s3/comment-page-1/