我已經瀏覽了很多其他帖子,我很迷惘。節點JS req.body undefined
我可以運行console.log(req)
,並得到下面的輸出
ServerResponse {
...
req:
IncomingMessage {
...
url: '/my-endpoint',
method: 'POST',
statusCode: null,
statusMessage: null,
...
body: { foo: 'bar' },
_body: true,
...
route: Route { path: '/my-endpoint', stack: [Object], methods: [Object] } },
...
看上去結實,所以我希望做console.log(req.body)
並獲得{ foo: 'bar' }
回到控制檯...但沒了,越來越不確定
經過研究,我發現它可能與我的app.js
文件有關,特別是與body-parser
,但是,我已經全部都是
var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var http = require('http');
var app = express();
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'pug');
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
//Home Page Rendering
var index = require('./routes/index');
app.use('/', index);
// All other routes are kept in the `routes` module
require('./routes')(app);
module.exports = app;
routes.js
module.exports = function routing(app) {
var apiClient = require('./services/apiClient');
app.post('/get-device-info', function(err, req, res){
console.log("/get-device-info routes");
apiClient(req, res);
});
};
apiClient.js
module.exports = function callApi(req, res){
console.log(req);
console.log(req.body)
};
index.js
var express = require('express');
var router = express.Router();
/* GET home page. */
router.get('/', function(req, res, next) {
res.render('index', { title: 'Express' });
});
module.exports = router;
這是我已經試過
app.use(express.bodyParser());
確保傳入的請求被明確聲明應用程序/ JSON
聲明在其他方面
添加配置功能
您使用表達的版本?你可能希望堅持4.x和單獨的'body-parser'模塊,而不是'express.bodyParser'。你還可以包含索引路由功能嗎? –
他確實堅持獨立的身體解析器... –
我不知道爲什麼我被低估了這一點。向OP添加了更多代碼。我正在使用節點7.4.0並且表達4.15.0 –