POST для сервера Python Flask с узла / экспресса: OSError: неверный заголовок чанка - PullRequest
0 голосов
/ 12 октября 2018

Я пытаюсь опубликовать JSON на сервере фляги Python и получаю следующую ошибку:

OSError: Invalid chunk header

параметры заголовка

let apiParams = {
    host: "0.0.0.0",
    port: "5000",
    path: "/",
    method: "POST",
    headers: {
        "Content-Type": "application/json"
    }
};

почтовый запрос:

generatePostRequest(apiParams) {
        let req = http.request(apiParams, function (res) {
            console.log('Status: ' + res.statusCode);
            console.log('Headers: ' + JSON.stringify(res.headers));
            res.setEncoding('utf8');
            res.on('data', function (body) {
                console.log('Body: ' + body);
            });
            req.on('error', function(e) {
                console.log('problem with request: ' + e.message);
            });
        });
        return req;
}
 let req = this.generatePostRequest(apiParams);
 req.write(JSON.stringify({text:"this is only a test"}));  

вывод console.log

Headers: {"content-type":"application/json","content-length":"37","server":"Werkzeug/0.14.1 Python/3.7.0","date":"Fri, 12 Oct 2018 17:46:23 GMT"}
Body: {"message": "Internal Server Error"}

простой запрос get работает

getRequest() {
        let res = fetch('http://0.0.0.0:5000') 
        .then((response) => {        
             return response.json();
        })    
        .then(function(data){
            console.log(data);
            return data;
        })
        .catch(function(e) {      
            console.log(e);
        });    
        return res;
    }

ОБНОВЛЕНИЕ

за предложение в комментариях ниже (спасибо @robertklep) Я обновил следующее:

let req = this.generatePostRequest(apiParams);
req.write(json);    
req.end();

Это работает сейчас!

1 Ответ

0 голосов
/ 14 октября 2018

Когда вы используете req.write(), Node.js по умолчанию будет использовать «кодирование передачи по частям» , что означает, что каждый вызов req.write() будет отправлять часть данных на HTTP-сервер, которому предшествует bytecount.

Я предполагаю, что Werkzeug истекает, потому что вы не заканчиваете запрос (поэтому Werkzeug ожидает новый чанк или конец запроса, но это не такполучить его, и в какой-то момент он выдаст ошибку).

Чтобы завершить запрос, вам нужно явно вызвать req.end(), когда вы закончите:

let req = this.generatePostRequest(apiParams);
req.write(JSON.stringify({text:"this is only a test"}));  
req.end();

Или, если выиметь фиксированный объем данных для отправки, вы можете объединить req.write и req.end:

let req = this.generatePostRequest(apiParams);
req.end(JSON.stringify({text:"this is only a test"}));  
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...