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 mailing list
nginx-ru@nginx.org
http://mailman.nginx.org/mailman/listinfo/nginx-ru

Ответить