ПРОЕКТЫ 


  АРХИВ 


Apache-Talk @lexa.ru 

Inet-Admins @info.east.ru 

Filmscanners @halftone.co.uk 

Security-alerts @yandex-team.ru 

nginx-ru @sysoev.ru 


  СТАТЬИ 


  ПЕРСОНАЛЬНОЕ 


  ПРОГРАММЫ 



ПИШИТЕ
ПИСЬМА












     АРХИВ :: nginx-ru
Nginx-ru mailing list archive (nginx-ru@sysoev.ru)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: PCRE



Hello!

On Wed, Feb 24, 2010 at 06:25:05AM -0500, anyhow2 wrote:

> Написал в конфиге:
>             if ($QUERY_STRING ~* ^.*(\\x){3,}.*$) {
>                 return 403;
>             }
> Запускаю
> /etc/rc.d/rc.nginx start
> Starting Nginx server daemon...
> : pcre_compile() failed: missing ) in "^.*(\x" in /etc/nginx/nginx.conf:131
> 
> Ладно, я не гордый, с учетом того, что могу и три раза скопипастить 
> переписываю так
>             if ($QUERY_STRING ~* ^.*\\x.*$) {
>                 return 403;
>             }
> 
> http://site.ru/page?r=\\xd0\\xb7\xd0\xb2\xd0\xb5\xd1\x80\xd1\x8c+\xd1\x82\xd1\x85\xd0\xbe\xd1\x80
> не режектит :(
> 
> Смотрю логи:
> 2010/02/24 14:20:16  16197#0: *10 "^.*\x.*$" does not match 
> "r=\\xd0\\xb7\xd0\xb2\xd0\xb5\xd1\x80\xd1\x8c+\xd1\x82\xd1\x85\xd0\xbe\xd1\x80
> 
> \\x[0-9] тоже пробовал. Тоже не матчит. Что я не так делаю?

Один '\' убирает nginx на парсинге конфига, до pcre долетает один 
(в строке лога приведено регулярное выражение в том виде, в 
котором оно отдано pcre) .  Как pcre трактует одинокий '\x' в 
регулярном выражении - не знаю, но вероятно обижается.

Добавьте ещё один обратный слэш - и будет вам счастье.  Ну и 
бессмысленный мусор уберите.  Как-то так:

    if ($args ~* "\\\x") {
        return 403;
    }


Maxim Dounin

_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://nginx.org/mailman/listinfo/nginx-ru

  • References:
    • PCRE
      • From: anyhow2

 




Copyright © Lexa Software, 1996-2009.