我正在尝试从一个node.js进程(客户端)向另一个(服务器)发送一个数组。
我在“client”node.js上的代码:
var express = require('express');
var app = express();
var config = require('./config');
var bodyParser = require('body-parser');
var methodOverride = require('method-override');
var request = require('request');
app.set('port', process.env.PORT || 3009);
app.use(bodyParser.json()); // parse application/json
app.use(bodyParser.json({ type: 'application/vnd.api+json' })); // parse application/vnd.api+json as json
app.use(bodyParser.urlencoded({ extended: true })); // parse application/x-www-form-urlencoded
app.use(methodOverride('X-HTTP-Method-Override')); // override with the X-HTTP-Method-Override header in the request. simulate DELETE/PUT
var arr = [{
date : "2016/1/26",
count: 6
},
{
date : "2016/1/27",
count: 0
},
{
date : "2016/1/28",
count: 0
},
{
date : "2016/1/29",
count: 0
},
{
date : "2016/1/30",
count: 0
},
{
date : "2016/1/31",
count: 2
},
{
date : "2016/2/1",
count: 0
},
{
date : "2016/2/2",
count: 4
}];
request.post({
uri: config.URL,
headers: {
'Content-Type':'application/json;charset=UTF-8',
'Accept-Encoding':'gzip, deflate',
'X-Requested-With': 'XMLHttpRequest',
'Accept':'application/json, text/plain, */*',
'User-Agent': 'UserAgent'
},
body: arr
}, function(err, res, body){
//whatever
});
在服务器端,我只收到info和console.log。
启动代码时,我进入客户端:TypeError('first argument must be a string, Array, or Buffer');
为什么我不能发送数组?我发誓我做了1000次......
如果我在客户端中将数组字符串化为:body: JSON.stringify(arr)
并且在服务器中我尝试将其解析回如下数组:var data = JSON.parse(req.body);
我在解析数据时在服务器中收到以下错误:
SyntaxError: Unexpected token o
at Object.parse (native)
at exports.uploadReads (C:\node\stockare2\server\companys\companys.controller.js:628:21)
at Layer.handle [as handle_request] (C:\node\stockare2\node_modules\express\lib\router\layer.js:95:5)
at next (C:\node\stockare2\node_modules\express\lib\router\route.js:131:13)
at uploadUser (C:\node\stockare2\server\companys\companys.routes.js:117:7)
at Layer.handle [as handle_request] (C:\node\stockare2\node_modules\express\lib\router\layer.js:95:5)
at next (C:\node\stockare2\node_modules\express\lib\router\route.js:131:13)
at Route.dispatch (C:\node\stockare2\node_modules\express\lib\router\route.js:112:3)
at Layer.handle [as handle_request] (C:\node\stockare2\node_modules\express\lib\router\layer.js:95:5)
at C:\node\stockare2\node_modules\express\lib\router\index.js:277:22
at Function.process_params (C:\node\stockare2\node_modules\express\lib\router\index.js:330:12)
at next (C:\node\stockare2\node_modules\express\lib\router\index.js:271:10)
at serveStatic (C:\node\stockare2\node_modules\express\node_modules\serve-static\index.js:74:16)
at Layer.handle [as handle_request] (C:\node\stockare2\node_modules\express\lib\router\layer.js:95:5)
at trim_prefix (C:\node\stockare2\node_modules\express\lib\router\index.js:312:13)
at C:\node\stockare2\node_modules\express\lib\router\index.js:280:7
如果我在尝试解析数据之前使用console.log req.body,我可以看到数据格式奇怪:
{ '{"date":"2016/1/26......
答案 0 :(得分:2)
尝试在请求中添加选项json: true
:
request.post({
uri: config.URL,
headers: {
'Content-Type':'application/json;charset=UTF-8',
'Accept-Encoding':'gzip, deflate',
'X-Requested-With': 'XMLHttpRequest',
'Accept':'application/json, text/plain, */*',
'User-Agent': 'UserAgent'
},
json: true,
body: arr
}, function(err, res, body){
答案 1 :(得分:0)
使用var data = eval(req.body)
转换为javascript对象。