Ошибка «HTTP :: Содержание сообщения должно быть в байтах» при попытке публикации - PullRequest
2 голосов
/ 01 июня 2010

У меня есть следующий код:

...
sub setImage {
    my $self=shift;
    my $filename=shift;
    unless(-r $filename) {
        warn "File $filename not found";
        return;
    }
    my $imgn=shift;
    my $operation=&URI::Escape::uri_escape_utf8(
        (shift) ? "Удалить! (Delete)" : "Сохранить! (Store)");
    my $FH=&::File::open($filename, 0, 0);
    my $image;
    # &utf8::downgrade($image);
    sysread($FH, $image, 102400, 0);
    close $FH;
    my $imginfo=eval{&Image::Info::image_info(\$image)};
    if($@ or $imginfo->{"error"}) {
        warn "Invalid image: ".($@ || $imginfo->{"error"});
        return undef;
    }
    my $fields=[
        DIR       => $self->url("fl"),
        OPERATION => $operation,
        FILE_NAME => ".photo$imgn",
        # FILE      => [$filename],
        FILE      => [undef, "image.".$imginfo->{"file_ext"},
            # Content_Type => $imginfo->{"file_media_type"},
            # Content_Type => 'application/octet-stream',
            Content      => $image,
        ],
    ];
    my $response=&ZLR::UA::post(
        &ZLR::UA::absURL("/cgi-bin/file_manager")."",
        $fields,
        Content_Type => "form-data",
    );
    print $response->decoded_content;
}
...

Когда я пытаюсь использовать функцию setImage, происходит сбой с ошибкой HTTP::Message content must be bytes at /usr/lib64/perl5/vendor_perl/5.8.8/HTTP/Request/Common.pm line 91. Хуже того, что я не могу воспроизвести эту ошибку, не используя весь мой код, а обновление libwww-perl ничего не делает. Чем это может быть вызвано?

Версии libww-perl: dev-perl / libwww-perl-5.836. HTTP :: Request и HTTP :: Request :: Common пришли из пакета libwww-perl, версии: 5.827 и 5.824.

Трассировка:

HTTP::Message content must be bytes at /usr/lib64/perl5/vendor_perl/5.8.8/HTTP/Request/Common.pm line 91
 at Carp::croak(unknown source)
 at HTTP::Message::__ANON__(/usr/lib64/perl5/vendor_perl/5.8.8/HTTP/Message.pm:16)
 at HTTP::Message::_set_content(/usr/lib64/perl5/vendor_perl/5.8.8/HTTP/Message.pm:136)
 at HTTP::Message::content(/usr/lib64/perl5/vendor_perl/5.8.8/HTTP/Message.pm:125)
 at HTTP::Request::Common::POST(/usr/lib64/perl5/vendor_perl/5.8.8/HTTP/Request/Common.pm:91)
 at LWP::UserAgent::post(/usr/lib64/perl5/vendor_perl/5.8.8/LWP/UserAgent.pm:397)
 at ZLR::UA::post(./zlrchecker.pl:71)
 at ZLR::Info::setImage(./zlrchecker.pl:1754)
 at main::main(./zlrchecker.pl:3893)
 at main::(./zlrchecker.pl:4148)

Ответы [ 2 ]

4 голосов
/ 01 июня 2010

Используйте Devel :: SimpleTrace и вставьте трассировку. Установите модуль с помощью cpan. Затем запустите вашу программу с -MDevel::SimpleTrace как perl -MDevel::SimpleTrace ./myapp_run.pl

И вставьте версию HTTP::Request:Common, HTTP::Message и LWP.

Полагаю, вы увидите это в трассировке стека:

Кажется, это код, который может вызвать ошибку :

*_utf8_downgrade = defined(&utf8::downgrade) ?
    sub {
        utf8::downgrade($_[0], 1) or
            Carp::croak("HTTP::Message content must be bytes")
    }
    :
    sub {
    };

Документы в utf8 говорят это:

Сбой, если исходная последовательность UTF-X не могут быть представлены в родной 8 битовое кодирование. При неудаче умирает или, если значение FAIL_OK равно true, возвращает ложь.

Вы должны быть в состоянии выполнить тестовый пример, запустив utf8::downgrade($http_message_content)

0 голосов
/ 20 октября 2014

Одно эффективное решение, которое я нашел для этой проблемы, заключалось в анализе любого текста, который мы помещаем в HTTP :: Message, во время HTTP-запроса, через unidecode() из Text::Unidecode.

...