index internal redirect

Валентин Бартенев ne на vbart.ru
Вс Июн 19 19:44:14 MSD 2011


On Sunday 19 June 2011 16:16:56 Gena Makhomed wrote:
> 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 сейчас, только инвертируя 
результат проверки.

В примере выше, если файл есть, то обработка произойдет в location @php.

Точно также, как при
try_files  $uri  @php;
обработка запроса произошла бы в @php при отсутствии файла.

 ! - как я полагаю, всем знакомый оператор.

> вместо такого sendmail-подобного расширения синтаксиса:
> 
> try_files  $uri на php $uri/  =404;
> 
> предлагаю лучше читаемый и лучше расширяемый вариант синтаксиса:
> 
> try_files  internal_redirect( @php )::$uri
>             $uri/
>             =404
>             ;

Извините, я не знаком с sendmail, но то, что вы предложили, выглядит длиннее 
страшнее и непонятнее. К тому же, не дает возможности написать, например, 
такую конструкцию:

try_files  $uri.php на php $uri/@dir_list $uri  =404;
 
> Если директива alias используется внутри location'а, заданного
> регулярным выражением, то регулярное выражение должно содержать
> выделения, а директива alias — ссылки на эти выделения
> 
> вполне полезно и разумно, потому что помогает защититься
> от случайных опечаток и ошибок при конфигурировании nginx.

Приведите пример такой ошибки. Я не очень понимаю, от чего это помогает 
защититься, а также страшных последствий, от "случайных опечаток и ошибок" в 
данном случае.

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

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

В данном случае, приходится писать что-то вроде:

root путь/к/директории/c/файлом;
try_files файл =404;

Но директива try_files по смыслу, как мне кажется, не для этого задумывалась, и 
логика ее работы сложнее, чем простой alias.

Ну или, как вы предложили, alias с пустым выделением, что еще более некрасиво.

--
Валентин Бартенев


Подробная информация о списке рассылки nginx-ru