Re: BugReport: ./configure --add-module неправильно подключает filter модуль

Denis Erygin erygin at corp.mail.ru
Sat Jun 9 19:53:09 MSD 2007


1)
>> Можно его использовать для чтения ответа?
>Да.

А где там данные?

Первый параметер "ngx_http_request_t* r" их вроде не содержит,
далее "void* data" - это пользовательские данные из ngx_http_post_subrequest_t:
struct ngx_http_post_subrequest_t {
    ngx_http_post_subrequest_pt  handler;
    void* data;
};
которые присваиваются до вызова ngx_http_subrequest.

2) Можно ли делать так (при условии что in->buf->last_buf = 1):

static ngx_int_t ngx_http_my_body_filter ( ngx_http_request_t* r, ngx_chain_t* in )
{
    ngx_buf_t*  b;
    ........
    b = ngx_calloc_buf (r->pool);
    if (b == NULL) return NGX_ERROR;

    b->memory = 1;
    b->pos    = (u_char*)"<!-- Served by my module -->";
    b->last   = b->pos + sizeof("<!-- Served by my module -->") - 1;

    in->buf = b;  // Заменили буфер, что будет со старым буфером? 
                      // Будет ли освобожден старый буфер до след. запроса?

    return ngx_http_next_body_filter ( r, in );
}

----- Original Message ----- 
From: "Igor Sysoev" <is at rambler-co.ru>
To: <nginx-ru at sysoev.ru>
Sent: Friday, June 08, 2007 11:55 PM
Subject: Re: BugReport: ./configure --add-module неправильно подключает filter модуль


On Fri, Jun 08, 2007 at 11:40:21PM +0400, Denis Erygin wrote:

> >Что значит - перехватить?
> 
> Перехватить, значит прочитать ответ и исключить его из вывода браузеру.
> В каком месте он добавляется к результирующему ответу браузеру?

В postpone фильтре. На самом деле, SSI + вся инфраструктура subrequest по 
сложности сравнима со всем nginx'ом. Это не самая удачная часть,
с которой можно начинатиь писать под nginx.

Прочитать и исключить ответ можно так, как сделано в

<!--# include virtual="/remote/body.php?argument=value" set="one" -->

> Например, если смотреть ngx_http_addition_filter_module.c , то там просто
> вызываются ngx_http_subrequest, а затем в браузере появляется их вывод,
> хотя явных манипуляций с цепочками буферов (ngx_chain_t) там нет...
> 
> >Этот handler вызывается по окончании подзапроса.
> Можно его использовать для чтения ответа?

Да.

> Насчет логики цепочек (ngx_chain_t):
> Если нужно заменить один из буферов на другой меньшего/большего размера,
> то как это правильно сделать в стиле nginx? Простая замена указателя на 
> chain->buf->pos
> может привести к утечке памяти.

Если буфер указывает на другую память, то лучше его создать и поставить
укзатели.

Замена указателей к утечке не приводит.


-- 
Игорь Сысоев
http://sysoev.ru
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://nginx.org/pipermail/nginx-ru/attachments/20070609/e9a06ec0/attachment.html>


More information about the nginx-ru mailing list