Welcome! Log In Create A New Profile

Advanced

Re: index internal redirect

Gena Makhomed
June 19, 2011 08:18AM
On 16.06.2011 23:16, Валентин Бартенев wrote:

>> Для try_files хотелось бы придумать ещё два модификатора - делать
>> внутренний редирект при нахождении файла (как сейчас делается для index)
>> и проверка абсолютного пути (а не относительно root/alias).
>> Например, абсолютный путь - два начальных слэша:
>>
>> try_files //path/to/maintenance.html $uri $uri/ @php;
>
> try_files !$uri @php;
>
> где ! - инвертирует результат обнаружение файла.

не совсем понятно, как этот синтаксис должен работать.
что делать в том случае, если файла действительно нет?
и что надо делать в том случае, когда такой файл есть?

> Или такая запись:
>
> try_files $uri@php $uri/ =404;
>
> т. е. @name, приставленная вплотную к конкретному пути, говорит нам о том, что
> если этот путь найден то обрабатываем его в @name

вместо такого sendmail-подобного расширения синтаксиса:

try_files $uri@php $uri/ =404;

предлагаю лучше читаемый и лучше расширяемый вариант синтаксиса:

try_files internal_redirect( @php )::$uri
$uri/
=404
;

> Извините, что несколько не по теме, но для alias хотелось бы иметь возможность
> писать так:
>
> location ~* ^/[a-z0-9\.]+\.(pgp|gpg|key)$ {
> alias /www/http/_global/key.pgp;
> }
>
> т. е. location с регуляркой и без выделений, а alias на конкретный файл.

разве это сейчас нельзя сделать, - если в location создать выделение,
которое всегда будет равно пустой строке и добавить его в строку alias?

проверил на тестовом сервере с nginx 1.0.0:

location ~* (.?)^/[a-z0-9\.]+\.(pgp|gpg|key)$ {
alias $1/etc/nginx/site/q/global_key.pgp;
}

это работает как и ожидалось, и $1 вcегда равно пустой строке.

в то же время, текущее поведение nginx:

Если директива alias используется внутри location'а, заданного
регулярным выражением, то регулярное выражение должно содержать
выделения, а директива alias — ссылки на эти выделения

вполне полезно и разумно, потому что помогает защититься
от случайных опечаток и ошибок при конфигурировании nginx.

лучше ничего не менять и не убирать это ограничение, тем более,
что оно очень легко обходится, если это действительно кому-то надо.

P.S. разве что имеет смысл добавить в документацию nginx
описание метода преднамеренного обхода этого ограничения.

--
Best regards,
Gena


_______________________________________________
nginx-ru mailing list
nginx-ru@nginx.org
http://nginx.org/mailman/listinfo/nginx-ru
Subject Author Posted

index internal redirect

Igor Sysoev June 16, 2011 02:28PM

Re: index internal redirect

Valery Kholodkov June 16, 2011 02:34PM

Re: index internal redirect

Igor Sysoev June 16, 2011 03:00PM

Re: index internal redirect

Valery Kholodkov June 16, 2011 03:40PM

Re: index internal redirect

Gena Makhomed June 19, 2011 10:30AM

Re: index internal redirect

Gena Makhomed June 19, 2011 10:44AM

Re: index internal redirect

Валентин Бартенев June 16, 2011 04:20PM

Re: index internal redirect

Gena Makhomed June 19, 2011 08:18AM

Re: index internal redirect

Валентин Бартенев June 19, 2011 11:48AM

Re: index internal redirect

Gena Makhomed June 19, 2011 12:20PM

Re: index internal redirect

Валентин Бартенев June 19, 2011 01:28PM

Re: index internal redirect

Gena Makhomed June 19, 2011 03:20PM

Re: index internal redirect

Gena Makhomed June 17, 2011 04:24PM

Re: index internal redirect

Gena Makhomed June 19, 2011 07:52AM

Re: index internal redirect

Gena Makhomed June 19, 2011 08:50AM

Re: index internal redirect

ruv June 20, 2011 03:54AM

Re: index internal redirect

Maxim Dounin June 16, 2011 03:58PM

Re: index internal redirect

Kirill A. Korinskiy June 16, 2011 04:00PM

Re: index internal redirect

Andrey N. Oktyabrski June 17, 2011 12:56AM

Re: index internal redirect

Gena Makhomed June 19, 2011 09:10AM



Sorry, only registered users may post in this forum.

Click here to login

Online Users

Guests: 204
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready