Re: location + rewrite и (де)кодирование URI
Maxim Dounin
mdounin на mdounin.ru
Ср Июн 19 11:54:10 UTC 2019
Hello!
On Tue, Jun 18, 2019 at 04:45:13PM +0300, Gena Makhomed wrote:
> On 18.06.2019 15:26, Maxim Dounin wrote:
>
> > И снова эксперимент плохой, негодный.
>
> Вот полный конфиг тестового сервера:
>
> server {
> listen 8080;
>
> 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 с необходимостью снятия/восстановления
экранирования - это один из наиболее простых путей.
--
Maxim Dounin
http://mdounin.ru/
Подробная информация о списке рассылки nginx-ru