JSON応答を含む私のモデルは次のとおりです。
exports.getUser = function(req, res, callback) {
User.find(req.body, function (err, data) {
if (err) {
res.json(err.errors);
} else {
res.json(data);
}
});
};
ここでは、http.requestから取得します。 JSONではなく文字列を(データ)受け取るのはなぜですか?
var options = {
hostname: '127.0.0.1'
,port: app.get('port')
,path: '/users'
,method: 'GET'
,headers: { 'Content-Type': 'application/json' }
};
var req = http.request(options, function(res) {
res.setEncoding('utf8');
res.on('data', function (data) {
console.log(data); // I can't parse it because, it's a string. why?
});
});
reqA.on('error', function(e) {
console.log('problem with request: ' + e.message);
});
reqA.end();
JSONを取得するにはどうすればよいですか?
httpはデータを文字列として送受信します...これはまさに物事です。文字列をjsonとして解析しようとしています。
var jsonObject = JSON.parse(data);
Json:trueを使用していることをリクエストに伝え、ヘッダーと解析を忘れる
var options = {
hostname: '127.0.0.1',
port: app.get('port'),
path: '/users',
method: 'GET',
json:true
}
request(options, function(error, response, body){
if(error) console.log(error);
else console.log(body);
});
投稿についても同じ
var options = {
hostname: '127.0.0.1',
port: app.get('port'),
path: '/users',
method: 'POST',
json: {"name":"John", "lastname":"Doe"}
}
request(options, function(error, response, body){
if(error) console.log(error);
else console.log(body);
});
json
オプションをtrue
に設定するだけで、ボディには解析されたjsonが含まれます。
request({
url: 'http://...',
json: true
}, function(error, response, body) {
console.log(body);
});