Ich versuche, ein Array von einem node.js-Prozess (Client) an einen anderen (Server) zu senden.Anfrage node.js POST-Array "erstes Argument muss Zeichenfolge oder Puffer sein"
Mein Code auf "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
});
Auf der Serverseite erhalte ich nur die Informationen und console.log es.
Wenn Sie den Code starten, bin ich in Client-bekommen: TypeError('first argument must be a string, Array, or Buffer');
Warum kann ich nicht Arrays schicken? Ich würde schwöre, ich habe es 1000 mal gemacht ...
Wenn ich das Array in Client wie diese stringify: body: JSON.stringify(arr)
und in Server versuche ich es zu analysieren, zurück zu einem Array wie folgt: var data = JSON.parse(req.body);
erhalte ich die folgende Fehler in dem Server beim Parsen der Daten:
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
Wenn ich req.body console.log, bevor Sie versuchen, die Daten zu analysieren, ich die Daten in einem fremden Format zu sehen ist:
{ '{"date":"2016/1/26......
Sie sollten wirklich vor eval() zurückschrecken, besonders wenn Ihr Anfragetext etwas enthält, das von einem Endbenutzer generiert wurde. Ref: https://Stackoverflow.com/questions/197769/when-is-javascripts-eval-not-evil –