Nan prèske nenpòt aplikasyon entènèt ki sèvi ak imaj, gen yon bezwen yo kreye ti kopi imaj sa yo, e souvan gen plizyè fòma pou imaj adisyonèl.
Ajoute nouvo dimansyon nan yon aplikasyon ki deja egziste tou lakòz kèk tèt fè mal. Pakonsekan travay la:
Objektif Travay la
Ann endike lis kondisyon yo:
Jenere imaj adisyonèl nan nenpòt fòma sou vole san yo pa entwodwi plis fonksyonalite nan aplikasyon an nenpòt ki lè pandan egzistans aplikasyon an;
Imaj adisyonèl pa bezwen pwodwi sou chak demann;
Enfim kapasite pou jenere imaj adisyonèl nan fòma ki pa espesifye.
Mwen pral eksplike dènye pwen an, paske li yon ti kras kontredi premye pwen an. Si nou fè jenerasyon nenpòt imaj louvri, Lè sa a, gen yon posibilite pou yon atak sou sit la pa jenere yon gwo kantite demann pou redimensionner imaj la nan yon kantite enfini fòma, kidonk vilnerabilite sa a bezwen fèmen.
nginx enstalasyon konfigirasyon
Pou rezoud kondisyon ki anwo yo nou bezwen seri modil nginx sa yo:
Modil yo ngx_http_image_filter_module и ngx_http_secure_link_module yo pa enstale pa default, kidonk yo dwe espesifye nan etap konfigirasyon enstalasyon an nginx:
Nou ajoute yon nouvo nan konfigirasyon lame nou an kote ak paramèt kachèt jeneral:
...
proxy_cache_path /www/myprojects/cache levels=1:2 keys_zone=image-preview:10m;
...
server {
...
location ~ ^/preview/([cir])/(.+) {
# Тип операции
set $oper $1;
# Параметры изображения и путь к файлу
set $remn $2;
# Проксируем на отдельный хост
proxy_pass http://myproject.ru:81/$oper/$remn;
proxy_intercept_errors on;
error_page 404 = /preview/404;
# Кеширование
proxy_cache image-preview;
proxy_cache_key "$host$document_uri";
# 200 ответы кешируем на 1 день
proxy_cache_valid 200 1d;
# остальные ответы кешируем на 1 минуту
proxy_cache_valid any 1m;
}
Malgre ke mwen ta rekòmande tou pou kalkile gwosè yo preview.
Rato
Lè w ap efase imaj orijinal la, aperçu, natirèlman, pa pral efase nan kachèt la jiskaske kachèt la invalid, ak nan ka nou an, aperçu ka egziste pou yon jou apre sipresyon, men sa a se tan an maksimòm.