请求正文在express中的路由器内部未定义



我有一个小型的express应用程序,它由服务器、一些视图和路由器组成。这是我的服务器.js:

const express = require('express');
const helmet = require('helmet');
const app = express();
app.use(helmet.contentSecurityPolicy({ directives: { defaultSrc: ["'self'"], scriptSrc: ["'self'", 'maxcdn.bootstrapcdn.com', 'ajax.googleapis.com'], styleSrc: ["'self'", 'maxcdn.bootstrapcdn.com'], imgSrc: ["'self'", 'image.tmdb.org'] } }));
const path = require('path');
const bp = require('body-parser');
const routes = require('./routes/index');
app.set('view engine', 'ejs');
app.set('views', path.join(__dirname, 'views'));
app.set(express.json());
app.set(bp.urlencoded({extended: false}));
app.set(bp.json())
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', routes);
app.listen(3000, () => {
console.log('Servidor online');
})

这是我的路由器js:

const express = require('express');
const request = require('request');
const router = express.Router();

router.post('/search', (req, res, next) => {
console.log(req.body);
res.send('sanity check');       
});
module.exports = router;

这是视图(这是导航栏内的一个表格(:

<nav class="navbar navbar-default">
<div class="container-fluid">
<div class="navbar-header">
<a class="navbar-brand" href="/">The New IMDB</a>
</div>
<ul class="nav navbar-nav">
<li><a href="/login">Login</a></li>
<li><a href="/favorites">Favorites</a></li>
</ul>
<ul class="nav navbar-nav navbar-right">
<li>
<form action="/search?source=hp" method="POST" id="search-form" class="form-inline">
<div class="form-group">
<select name="categ" class="form-control" id="cat">
<option value="movie">Movie Title</option>
<option value="person">Actor</option>
</select>
</div>
<input type="text" id="movie" placeholder="Search" name="movieSearchq" />

<input type="submit" class="btn btn-primary" />
</form>
</li>
</ul>
</div>
</nav>

我搜索了以前的问题,发现bodyParser不再与express一起提供,所以我安装了它,但它仍然没有在req中创建body对象。我是不是遗漏了什么?

由于使用app.set,您错误地将body-parser设置为解析表单数据(仅用于设置applyexpress设置(。

相反,您需要使用app.use:设置中间件

app.use(bp.urlencoded({extended: false}));
app.use(bp.json());

最新更新