节点JS req.body undefined

时间:2017-04-11 18:14:56

标签: node.js express

我已经浏览了很多其他帖子,而且我很失落。

我可以运行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());

确保传入请求明确声明application / json

以其他方式声明body parser.json

添加配置功能

2 个答案:

答案 0 :(得分:4)

你的问题是Express并没有使用error first callbacks作为其路由处理程序。以下代码无法使用,因为app.post处理程序没有签名(req, res) => {}。在下面的代码err等于reqreq等于resres等于next

// 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");

    // Assuming the request is correct 
    // the value of body will be the request body  
    console.log(res.body)

    apiClient(req, res);
  });
};`

您可以在Express

中使用3种不同的路由回调签名
  • (req, res) => {} - 这是最基本的,并定义了一个关心请求和响应的路由
  • (req, res, next) => {} - 这是一个中间件回调签名,看起来像一个基本的路由回调,但它也分配了next对象,告诉Express调用下一个匹配的路由。
  • (err, req, res, next) => {} - 这是错误处理路由回调,每个Express路由器中间件或Express App只需要1个。如果在路由或中间件中调用next(err),则会调用它。更具体地说,如果next()没有用字符串调用或什么都不调用它将跳过所有剩余的中间件和路由并直接进入错误处理程序。您可以在Express Docs
  • 中详细了解相关信息

您需要将路线定义更改为

app.post('/get-device-info', (req, res) => {
  apiClient(req, res)
})

或者你甚至可以这样做

module.exports = app => {
  let apiClient = require('./services/apiClient')

  app.post('/get-device-info', apiClient)
}

答案 1 :(得分:0)

试试这个,因为它对我有用。

首先声明app然后bodyParser,因为在bodyParser中使用了app

const app           = express();
const bodyParser    = require('body-parser');

然后在下面这些行:

app.use(bodyParser.json())
app.use(bodyParser.urlencoded({extended: true}))
相关问题