ПРОЕКТЫ 


  АРХИВ 


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: Fake Content-Length header



----- init <nginx-forum@xxxxxxxx> wrote:
> Возможно ли настроить/пропатчить nginx
> так, чтобы он считал данные успешно
> принятыми, если их размер не равен
> Content-Length?

Возможно пропатчить.

 Клиента изменить нельзя. Я
> пробовал изменить функцию
> ngx_http_do_read_client_request_body() и убрать возврат
> ошибки при c->recv()==0 (записав при этом в
> rb->rest = 0), но это вызвало проблемы с
> последующей передачей запроса
> апстриму:

Есть подозрения, что будет работать, если вы обновите значение заголовка 
Content-Length:

    r->headers_in.content_length_n = <фактическая длина тела>;

    r->headers_in.content_length->value.data = ngx_palloc(r->pool, 
NGX_OFF_T_LEN);

    if (r->headers_in.content_length->value.data == NULL) {
        return NGX_HTTP_INTERNAL_SERVER_ERROR;
    }

    r->headers_in.content_length->value.len =
        ngx_sprintf(r->headers_in.content_length->value.data, "%O", 
r->headers_in.content_length_n)
            - r->headers_in.content_length->value.data;

> 2011/10/06 08:37:30 [debug] 28656#0: *27 http upstream recv(): 0 (115:
> Operation now in progress)
> 2011/10/06 08:37:30 [info] 28656#0: *27 client closed prematurely
> connection, so upstream connection is closed too while connecting to
> upstream, clien
> 2011/10/06 08:37:30 [debug] 28656#0: *27 finalize http upstream request:
> 499

-- 
Regards,
Valery Kholodkov

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


 




Copyright © Lexa Software, 1996-2009.