2016-09-08 5 views
3

ノードを使用してFlaskにJSONデータを送信しようとしていますが、Flaskでデータを読み取ることができません。フラスコにrequest.dataという印刷を試みましたが、何も出力しませんでした。私はまた、request.jsonの印刷を試みましたが、400の応答を返しました。なぜFlaskはNodeから送られたJSONデータを見ないのですか? JavaScriptからFlaskにノードによって送信されたJSONデータが表示されない

from flask import Flask 
from flask import request 

app = Flask(__name__) 

@app.route("/", methods=['GET', 'POST']) 
def hello(): 
    if request.method == "POST": 
     print "POST"; 
     print "get_json: ", request.get_json(); 
     # print "get_json: ", request.get_json(force = True); 
     print "data: ", request.data; 
     return 'POST'; 
    else: 
     print "GET"; 
     return "GET"; 

if __name__ == "__main__": 
    app.run() 
var async = require('async'), 
    http = require('http'), 
    util = require('util'); 

var server = { 
     hostname: '127.0.0.1', 
     port: 5000 
    }; 

function request(method, path, headers, body, callback) { 
    var req = {}; 

    if(!headers) { 
     headers = {}; 
    } 

    headers['Content-Type'] = 'application/json'; 

    console.log(method + ' ' + path); 
    console.log(' Req:'); 
    console.log(' headers: ' + JSON.stringify(headers)); 
    if(body) { 
     console.log(' body : ' + JSON.stringify(body)); 
    } else { 
     console.log(' no body'); 
    } 

    req = http.request({ 
      hostname: server.hostname, 
      port: server.port, 
      path: path, 
      method: method, 
      headers: headers 
     }, (res) => { 
      var resbody = ''; 

      res.on('data', (chunk) => { 
       resbody = resbody + chunk; 
      }); 

      res.on('end',() => { 
       console.log(' Res:'); 
       console.log(' headers: ' + JSON.stringify(res.headers)); 
       if(body) { 
        console.log(' body : ' + JSON.stringify(resbody)); 
       } else { 
        console.log(' no body'); 
       }    
       callback(resbody); 
      }); 
     } 
    ); 

    req.on('error', (err) => { 
     console.log(method + ' ' + path + ' ERR: ' + util.inspect(err)); 
     callback(err); 
    }); 

    if(body) { 
     req.write(JSON.stringify(body)); 
    } 

    req.end(); 
} 

request('POST', '/', null, {foo: 'bar'}, (res) => {}); 

出力:

POST/
Req: 
    headers: {"Content-Type":"application/json"} 
    body : {"foo":"bar"} 
Res: 
    headers: {"content-type":"text/html","content-length":"192","server":"Werkzeug/0.11.11 Python/2.7.11","date":"Fri, 09 Sep 2016 10:29:58 GMT"} 
    body : "<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 3.2 Final//EN\">\n<title>400 Bad Request</title>\n<h1>Bad Request</h1>\n<p>The browser (or proxy) sent a request that this server could not understand.</p>\n" 

パイソンからの出力:に編集

POST 
get_json: 127.0.0.1 - - [09/Sep/2016 12:29:58] "POST/HTTP/1.1" 400 - 

すべてのコードを更新してください

カール:

> curl.exe 127.0.0.1:5000 --header "Content-Type: application/json" --data {\"foo\":\"bar\"} 
POST 
+0

あなたは 'HTTPを使用した場合:// httpbin.org/POST'あなたが送信したものエコーバックJSONレスポンスを得るだろう。同じ結果が得られます(POST本体では何も送信されません)。 –

+0

ああ、私はそれがJSONified本体を書いているのを見ています。私はContent-Lengthヘッダーが設定されているのを見ていません。 [node.js 'http.request()'ドキュメント](https://nodejs.org/api/http.html#http_http_request_options_callback)を見て、そのヘッダにそのコードを明示的に設定します。 –

+0

@davidism:同じ結果ですが、何も印刷されず、ノードに400エラーが発生します。 – DrakaSAN

答えて

0

ザ・パイソンServerは結構です、と正常に動作し、問題は、何らかの理由で不正な形式である手作りのhttpリクエスト、にあります。

requestモジュールは動作します使用:

var request = require('request'); 

request({ 
    method: 'POST', 
    url: 'http://127.0.0.1:5000', 
    // body: '{"foo": "bar"}' 
    json: {"foo": "bar"} 
}, (error, response, body) => { 
    console.log(error); 
    // console.log(response); 
    console.log(body); 
}); 
関連する問題