Opened 6 years ago

Closed 6 years ago

Last modified 6 years ago

#545 closed defect (worksforme)

Не обрабатывается переменная $http_if_modified_since

Reported by: openid.yandex.ru/romanov-toha Owned by:
Priority: minor Milestone:
Component: nginx-core Version: 1.5.x
Keywords: Cc:
uname -a: Linux blade1 2.6.32-358.18.1.el6.x86_64 #1 SMP Wed Aug 28 17:19:38 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux
nginx -V: nginx version: nginx/1.5.6
built by gcc 4.4.7 20120313 (Red Hat 4.4.7-3) (GCC)
TLS SNI support enabled
configure arguments: --user=nginx --group=nginx --prefix=/usr/share/nginx --sbin-path=/usr/sbin/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --http-client-body-temp-path=/var/lib/nginx/tmp/client_body --http-proxy-temp-path=/var/lib/nginx/tmp/proxy --http-fastcgi-temp-path=/var/lib/nginx/tmp/fastcgi --http-uwsgi-temp-path=/var/lib/nginx/tmp/uwsgi --http-scgi-temp-path=/var/lib/nginx/tmp/scgi --pid-path=/var/run/nginx.pid --lock-path=/var/lock/subsys/nginx --with-http_secure_link_module --with-http_random_index_module --with-http_ssl_module --with-http_realip_module --with-http_addition_module --with-http_sub_module --with-http_dav_module --with-http_flv_module --with-http_mp4_module --with-http_gzip_static_module --with-http_degradation_module --with-http_stub_status_module --with-http_perl_module --with-http_geoip_module --with-mail --with-mail_ssl_module --with-cc-opt='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic' --with-ipv6 --with-file-aio --add-module=/builddir/build/BUILD/nginx-1.5.6/nginx-upstream-fair --add-module=/builddir/build/BUILD/nginx-1.5.6/nginx-upload-progress-module --add-module=/builddir/build/BUILD/nginx-1.5.6/mod_zip-1.1.6 --add-module=/builddir/build/BUILD/nginx-1.5.6/ngx_http_auth_pam_module-1.2 --add-module=/builddir/build/BUILD/nginx-1.5.6/nginx-rtmp-module-master

Description

При наличии вот такого тестового правила:

location ~ ^/testifmod/
        {
                if ($http_if_modified_s != '')
                {
                        return 503;
                }
                if ($http_if_modified_since != '')
                {
                        return 503;
                }
        }

Делаю запрос:

wget -d --header="If-Modified-S: Mon, 21 Apr 2014 11:37:49 GMT" http://mysite/testifmod/
Выдаёт ошибку 503, гуд.

Делаю запрос:
wget -d --header="If-Modified-Since: Mon, 21 Apr 2014 11:37:49 GMT" http://mysite/testifmod/
Не выдаёт 503! Как так?

Change History (2)

comment:1 by Maxim Dounin, 6 years ago

Resolution: worksforme
Status: newclosed

Наиболее вероятная причина - в конфиге написано что-то ещё, и это "что-то" приводит к тому, что запрос обрабатывается в другом location'е.

Начните с того, что напишите конфиг полностью, как-то так:

events {
}

http {
    server {
        listen  8080;

        location /testifmod/ {
                if ($http_if_modified_s != '') {
                        return 503;
                }
                if ($http_if_modified_since != '') {
                        return 503;
                }
        }
    }
}

Отдельно отмечу, что использовать location'ы, заданные регулярными выражениями, без нужды - зло, и как раз часто приводит к тому, что представления администратора о том, где будет обрабатываться запрос, не совпадают с действительностью. Лучше использовать обычные location'ы, заданные префиксной строкой, см. http://nginx.org/r/location/ru.

comment:2 by openid.yandex.ru/romanov-toha, 6 years ago

Действительно.
Но что там срабатывает понять не могу.

Note: See TracTickets for help on using tickets.