Re: $r->request_body выдает ошибку если тело запроса пустое

Igor Sysoev is at rambler-co.ru
Fri Dec 22 19:06:28 MSK 2006


On Fri, 22 Dec 2006, Andrey Antonov wrote:

> Ошибку генерирует например такой код:
>
> sub handler{
>    my $r = shift;
>    if( $r->has_request_body(\&handle_request) ){
>        return OK;
>    } else {
>        return handle_request($r);
>    }
> }
>
> sub handle_request{
>    my $r = shift;
>    $r->request_body(); # если запрос сделан методом гет то здесь ошибка,
> выполнение хендлера прерывается
>    return OK;
> }
>
> Ну понятно, что можно в handler установить переменную, $r->request_body() в
> if запихать и все будет работать. Информация perl -V прилагается.

Там на самом деле процесс падает по сигналу, но вот сообщения про
"close() channel" у не появлется. Можно сделать отладочный лог ?

> 22.12.06, Igor Sysoev <is at rambler-co.ru> написал(а):
>>
>> On Fri, 22 Dec 2006, Andrey Antonov wrote:
>>
>> > Наконец-то перешел с 0.3.61 на 0.5.4, все что до этого не работало в
>> > 0.4.хтеперь работает, это здорово, весь новый функционал очень полезен
>> > для
>> > написания достаточно сложных хендлеров на перле.
>> > Заметил, что $r->request_body стало возвращать ошибку "close() channel
>> > failed (9: Bad file descriptor)" если тело запроса пустое (например в
>> > обычном гет запросе). Хорошо бы это пофиксить, тк сейчас надо либо
>> проверять
>> > тип запроса, либо переменную специальную устанавливать, что не удобно.
>>
>> Как выглядит перловый код ?
>>
>>
>> Игорь Сысоев
>> http://sysoev.ru
>>
>>
>

Игорь Сысоев
http://sysoev.ru





More information about the nginx-ru mailing list