implicit *LWS ?

Alexandre Snarskii snar на snar.spb.ru
Ср Окт 6 17:56:46 MSD 2010


On Wed, Oct 06, 2010 at 01:52:52PM +0100, Valery Kholodkov wrote:
> 
> Это фича. В Вашем запросе указан HTTP/1.0, следовательно смотреть 
> нужно в rfc 1945.
> 
> Относительно LWS rfc 1945 говорит (пункт 2.2):
> 
> However, folding of header lines is not expected by some
>    applications, and should not be generated by HTTP/1.0 applications.
> 
> Таким образом Ваш запрос не следует рекомендациям.

should not, вообще говоря, не запрещает использовать folding
(иначе здесь был бы must not), а просто "не рекомендует". 
А пункт 2.1 того же RFC1945 содержит примерно то же, что и в RFC2616,

 implied *LWS

       Except where noted otherwise, linear whitespace (LWS) can be
       included between any two adjacent words (token or
       quoted-string), and between adjacent tokens and delimiters
       (tspecials), without changing the interpretation of a field. 

То есть - LWS может использоваться, хотя это использование и не 
рекомендуется. 

> Если бы в Вашем запросе был указан HTTP/1.1, то это был бы баг.

Ok, повторяем тот же эксперимент заменяя в запросе HTTP/1.0 на HTTP/1.1, 
оставляя LWS на месте.  

И при proxy_pass и при fastcgi_pass получаем ровно то же поведение: 

T 192.168.13.202:47692 -> <...>:80 [AP]
GET /picture.jpg HTTP/1.0.
Host: ....
Connection: close.
Accept: text/plain, text/html,.
.

accept срезан на CRLF'е. Ok, этот запрос уже преобразован из HTTP/1.1
в HTTP/1.0, но если такое "обрезание" - это попытка следовать приведенной
Вами рекомендации - nginx, jimho, должен был заменить LWS на SP (как это 
делает, например, haproxy), ибо согласно и rfc1945 и 2616, LWS has the 
same semantics as SP (цитируется по 2616), а 2616 и вовсе добавляет, что

A recipient MAY replace any linear white space with a single SP before 
interpreting the field value or forwarding the message downstream.


> ----- Alexandre Snarskii <snar at snar.spb.ru> wrote:
> > 
> > Hi!
> > 
> > Дано: nginx/0.8.52 (собранный из FreeBSD ports без добавок), вот такой 
> > вот запрос (обратите внимание на linear white space внутри поля Accept): 
> > 
> > GET /picture.jpg HTTP/1.0
> > Accept: text/plain, text/html,
> >     */*
> > Host: .....
> > 
> > Пытаемся послать его через nginx с минимальным конфигом 
> > (location /picture.jpg { proxy_pass http://....; proxy_set_header Host ....; })
> > в ngrep'е видим следующее: 
> > 
> > T 192.168.13.202:52556 -> <....>:80 [AP]
> > GET /picture.jpg HTTP/1.0.
> > Host: ....
> > Connection: close.
> > Accept: text/plain, text/html,.
> > .
> > 
> > то есть nginx при проксировании обрезал весь контент поля начиная с CRLF.
> > 
> > То же самое происходит если пытаться передавать запрос на fastcgi backend,
> > в параметре HTTP_ACCEPT я вижу только text/plain, text/html, но не */*.
> > С другими хидерами происходит то же самое - как только встречается LWS - 
> > поле "обрезается", что для proxy_pass, что для fastcgi_pass. 
> > 
> > Вопрос: это бага или фича ? Если фича - обойти как-нибудь можно ? 
> > 
> > PS: по RFC судя - бага, RFC2616 в разделе 2.1 говорит о impled *LWS: 
> > 
> > implied *LWS
> > 
> >     The grammar described by this specification is word-based. Except 
> >   where noted otherwise, linear white space (LWS) can be included between 
> >   any two adjacent words (token or quoted-string), and between adjacent 
> >   words and separators, without changing the interpretation of a field. 
> 
> -- 
> Regards,
> Valery Kholodkov
> 
> _______________________________________________
> nginx-ru mailing list
> nginx-ru at nginx.org
> http://nginx.org/mailman/listinfo/nginx-ru

-- 
In theory, there is no difference between theory and practice. 
But, in practice, there is. 



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