index internal redirect

Gena Makhomed gmm на csdoc.com
Вс Июн 19 16:16:56 MSD 2011


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 at php $uri/  =404;
>
> т. е. @name, приставленная вплотную к конкретному пути, говорит нам о том, что
> если этот путь найден то обрабатываем его в @name

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

try_files  $uri at 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