node.js请求POST数组“第一个参数必须是字符串或缓冲区”

时间:2016-03-29 16:59:37

标签: javascript arrays json node.js request

我正在尝试从一个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......

2 个答案:

答案 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对象。