Node/Express JS“无法读取未定义的属性'username'”

3
在您将此标记为重复之前,请理解我查看的所有答案都与我的代码无关,无法解决问题。 我正在尝试修复一个网络应用程序中的错误,该应用程序可将文件从Internet上传到家庭服务器。 我目前正在研究基本用户身份验证系统。 当我尝试提交主页上的登录表单时,我被重定向到一个带有错误的页面,其中一部分说“无法读取未定义属性'用户名'”。 这条消息也出现在控制台中。 发生了什么事情,我该如何解决? 错误将我引导到主页控制器的第八行,“username = req.body.username”。App.js
var LocalStrategy = require('passport-local').Strategy;
var flash = require("connect-flash");
var passport = require("passport");
var session = require("express-session");
var expressValidator = require("express-validator");
var mongoose = require("mongoose");
var path = require('path');
var express = require('express');
var cookieParser = require('cookie-parser');
var app = express();
var bodyParser = require('body-parser');
var ejs = require('ejs');
var routes = require('./server/routes');   
routes(app);
app.set('port', process.env.PORT || 3000);
app.use(bodyParser.urlencoded({extended: false}));
app.use(bodyParser.json());
app.use(express.static(path.join(__dirname, 'public')));
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
app.use(cookieParser());
mongoose.connect("mongodb://localhost:27017/users");
app.listen(app.get('port'), function(){
  console.log("server started");
});
var db = mongoose.connection;
app.use(session({
  secret: 'yVVma9ga',
  saveUninitialized: true,
  resave: true
}));
app.use(passport.initialize());
app.use(passport.session());
app.use(expressValidator({
  errorFormatter: function(param, msg, value) {
      var namespace = param.split('.')
      , root    = namespace.shift()
      , formParam = root;

    while(namespace.length) {
      formParam += '[' + namespace.shift() + ']';
    }
    return {
      param : formParam,
      msg   : msg,
      value : value
    };
  }
}));
app.use(flash());
app.use(function(req,res,next) {
  res.locals.success_msg = req.flash('success_msg');
  res.locals.error_msg = req.flash('error_msg');
  res.locals.error = req.flash("error");
  next();
});

/server/routes.js

var express = require("express");
var home = require('../controllers/home');
var client = require('../controllers/client');
module.exports = function(app) {
    var router = express.Router();
    app.use('/', router);
    router.get('/', home.index);
    router.get('/client', client.home);
    router.post('/', home.login);
}

controllers/home.js

module.exports = {
    index: function(req, res){
        res.render("home");
    },
    login: function(req, res){
        var username = req.body.username;
        var password = req.body.password;
        req.checkBody('username', 'Username is required').notEmpty();
        req.checkBody('password', 'Password is required').notEmpty();
        var errors = req.validationErrors();
        if(errors){
            console.log("YES");
        }else{
            console.log("NO");
        };       
    }
}

/views/home.ejs(partials只是基本的HTML)
<% include partials/header %>
<p>Welcome to your personal server!</p>
<p>Login!</p>
<form method="post" action = "/">
<input placeholder="Username" type="text" name="username">
<input placeholder="Password" type="password" name="password">
<input type="submit" value="Submit">
</form>
<% include partials/footer %>
2个回答

9
我猜您在调用路由之前调用了bodyparser。尝试将路由移动到其下方。
更改为:
var routes = require('./server/routes');   
routes(app);
//...
app.use(bodyParser.urlencoded({extended: false}));
app.use(bodyParser.json());

To

var routes = require('./server/routes');
//...
app.use(bodyParser.urlencoded({extended: false}));
app.use(bodyParser.json());
//...
routes(app);

这个可以运行,但是我有一个新的 bug,错误信息是 checkBody 没有定义(在我的验证代码中)。我不确定这是否相关。 - Isaac Krementsov
这是因为你的路由器仍然在 express validator 之前。如果你在说 app.use 之前说 router (app),那么你的路由就没有你的中间件了。 - Gibryon Bhojraj
我是一个编程新手。在连接monogclient之前移动bodyparser对我有用。 - Sudhir Kaushik

1
var routes = require('./server/routes');

app.use(bodyParser.urlencoded({extended: false}));
app.use(bodyParser.json());
 //...
routes(app);

所有内容都应该在路由内部。如果不是,你就会遇到undefined错误。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接