Re: location + rewrite и (де)кодирование URI

Gena Makhomed gmm на csdoc.com
Ср Июн 19 13:46:46 UTC 2019


On 19.06.2019 14:54, Maxim Dounin wrote:

>>       location /wiki1/ {
>>           rewrite ^/wiki1/(.*) https://$host/$1;
>>       }
>>
>>       location /wiki2/ {
>>           rewrite ^/wiki2/(?<title>.*) https://$host/$title;
>>       }
>>
>> Вот запросы к первому и второму location`у:
>>
>> $ curl -I http://127.0.0.1:8080/wiki1/%D1%82%D0%B5%D1%81%D1%82
>> Location: https://127.0.0.1/%D1%82%D0%B5%D1%81%D1%82
>>
>> $ curl -I http://127.0.0.1:8080/wiki2/%D1%82%D0%B5%D1%81%D1%82
>> Location: https://127.0.0.1/тест
>>
>> Первый и второй location отличаются между собой только тем,
>> что в первом используется неименованное выделение $1,
>> а во втором - именованное выделение $title.
>>
>> И в то же время получаем такие разные результаты. Почему так?

> Потому что подстановка $1 делается из раскодированного URI
> запроса, и nginx знает, что данные в ней следует экранировать.  А
> $title - произвольная переменная, и как и любая произвольная
> переменная - подставляется в предположении, что данные в ней
> корректно экранированы.
> 
> В частности из-за этой магии обычно рекомендуют использовать
> return, где никакой подобной магии нет.  Но если речь идёт о
> изменениях URI с необходимостью снятия/восстановления
> экранирования - это один из наиболее простых путей.

Понятно, спасибо.

Можно ли научить nginx, чтобы он писал в лог warn в том случае, если он
отправляет клиенту редирект с URI, который не соответствует требованиям
RFC 3986, например, когда там незакодированный текст на русском языке?

Например, можно ли сделать фильтр на njs, который будет проверять
все отправляемые клиенту редиректы и писать в лог warn в случае
ошибок в кодировании URI?

Можно ли в документации к nginx написать о той магии, которая есть
в директиве rewrite, в частности с автоматическим кодированием $1,$2,$3
и отсутствии автоматического кодирования обычных переменных?

Можно ли научить nginx, чтобы он делал warning во время парсинга
и проверки конфига в том случае, если в левой и в правой части
директивы rewrite присутствует одно и то же именованное выделение?

Или же, вместо этого, сделать магию не только с $1,$2,$3
но и с именованными выделениями, если одна и та же переменная
присутствует и в левой и в правой части директивы rewrite ?

Тогда location /wiki1/ и /wiki2/ будут вести себя идентично.
Чем меньше будет в nginx подобных подводных камней - тем меньше
он будет похож на sendmail в плане конфигурирования и использования.

-- 
Best regards,
  Gena



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