Re: Модификация URL в nginx

Maxim Dounin mdounin на mdounin.ru
Вт Янв 24 14:58:58 UTC 2012


Hello!

On Tue, Jan 24, 2012 at 05:26:07PM +0300, Alexander F. wrote:

> Приветствую.
> Есть веб-сервер с nginx, отдающий картинки с бэкенда, URL картинок выглядит
> как:
> http://www.server.ru/cache/a1234/100483674_1337085766.jpg
> 
> Некоторые нехорошие почтовые сервисы при получении письма с такой ссылкой
> (в контексте html письма) ее модифицируют: ставят либо восклицательный
> знак, либо знак пробела "%20"; к примеру почтовый сервер libero.it приводят
> вышеуказанный URL к виду:
> http://www.server.ru/cache/a1234/100483!674_1337085766.jpg
> Соответственно, клиенты получают 404, что неприятно.

Это выглядит как явный и однозначный косяк почтового сервера.  Но 
почему-то я в это не верю, и более вероятным мне представляется 
косяк при формировании сообщений, e.g. вы формируете слишком 
длинные строки, которые в результате резбиваются на несколько и 
собираются обратно неправильно.  Возможно, имеет смысл зайти 
именно с этой стороны, а не городить затычки.

> Вопрос: возможно ли средствами nginx вырезать такие символы или их
> игнорировать, что бы клиенты не получали 404 ошибку.

Вырезать один восклицательный знак можно как-то так:

    location /cache/ {
        rewrite ^([!]*)!(.*) $1$2 break;
        proxy_pass ...
    }

В более общем случае (вырезать всё, что не alphanumeric/slash/dot, 
до трёх символов) как-то так:

    location /cache/ {
        rewrite ^([/a-z0-9.]+).([/a-z0-9.]*) $1$2;
        rewrite ^([/a-z0-9.]+).([/a-z0-9.]*) $1$2;
        rewrite ^([/a-z0-9.]+).([/a-z0-9.]*) $1$2;
        break;
        proxy_pass ...
    }

Maxim Dounin



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