在null
路由中从数据库中获取数据时,我总是得到undefined
/ /authenticate
。连接成功,用户存在于数据库中(使用Robo 3T进行检查)。以下是代码的摘录:
var express = require("express");
var app = express();
var router = express.Router();
var mongoose = require("mongoose");
var user = require("../models/user");
var bodyParser = require("body-parser");
app.use(bodyParser.json());
router.post('/authenticate', function(req, res) {
user.findOne({ name: req.body.name }).then(function(foundUser) {
if (!foundUser) { return res.status(404).send("No user matching name"); }
return res.status(200).json(foundUser);
});
});
以下是我从Postman执行的请求:
答案 0 :(得分:2)
编辑回答:
除了json之外,要快速解析表单数据,您需要在应用程序中添加第二个正文解析器:
var app = require('express');
var bodyParser = require('body-parser');
// Enable express to parse body data from raw application/json data
app.use(bodyParser.json());
// Enables express to parse body data from x-www-form-encoded data
app.use(bodyParser.urlencoded({ extended: false }));
答案 1 :(得分:0)
req.body.name
它可能为null,因此findOne()
可能会返回null
var query = user.findOne({name: req.params.name});
取决于您的路线调用方法,尝试使用req.params.name