javascript - Node.js 表单验证无法读取未定义的属性 'profileimage'

标签 javascript node.js express

我正在尝试按照教程使用 Express 在 Node.js 中创建一个表单。我正在编写验证逻辑,如果表单 提交为空,但是它没有这样做,而是在第 33 行给我这个错误,我不知道为什么:

Cannot read property 'profileimage' of undefined

我对其进行了调试,但无法弄清楚是什么原因造成的。 我做错了什么,我该如何解决?

表单代码如下:

var express = require('express');
var router = express.Router();

/* GET users listing. */
router.get('/', function(req, res, next) {
  res.send('respond with a resource');
});

router.get('/register', function(req, res, next) {
  res.render('register', {
      'title': 'Register'
  });
});

router.get('/login', function(req, res, next) {
  res.render('login', {
      'title': 'Log In'
  });
});

router.post('/register', function(req, res, next) {
  var name = req.body.name;
  var email = req.body.email;
  var username = req.body.username;
  var password = req.body.password;
  var password2 =  req.body.password2;


  // Check for Image Field
  if(req.files.profileimage){
      console.log('uploading File...');

      // File Info
      var profileImageOriginalName = req.files.profileimage.originalname;
      var profileImageName = req.files.profileimage.name;

      var profileImageMime = req.files.profileimage.mimetype;
      var profileImagePath = req.files.profileimage.path;
      var profileImageExt = req.files.profileimage.extension;
      var profileImageSize = req.files.profileimage.size;
  } else {
      // Set a Default Image
      var profileImageName = 'noimage.png';
  }

    // Form Validation

    req.checkBody('name','Name field is required').notEmpty();
    req.checkBody('email','Email field is required').notEmpty();
    req.checkBody('email','Email not valid').isEmail();
    req.checkBody('username','Username field is required').notEmpty();
    req.checkBody('password','Password field is required').notEmpty();
    req.checkBody('password2','Password do not match').equals(req.body.password);

    // Check for errors
    var errors = req.validationErrors();

    if(errors){
        res.render('register', {
            errors: errors,
            name: name,
            email: email,
            username: username,
            password: password,
            password2: password2
        });
    } else {
        var newUser = new User({
            name: name,
            email: email,
            username: username,
            password: password,
            profileImage: profileImageName
        });

            // Create User
            User.createUser(newUser, function(err, user){
                if(err)throw err;
                console.log(user);
            });

            //Success Message
            req.flash('success', 'You are now registered and may log in');

            res.location('/');
            res.redirect('/');
    }
});

module.exports = router;

和我的 app.js:

var express = require('express');
var path = require('path');
var logger = require('morgan');
var expressValidator = require('express-validator');
var cookieParser = require('cookie-parser');

var session = require('express-session');
var passport = require('passport');
var LocalStrategy = require('passport-local').Strategy;
var bodyParser = require('body-parser');
var multer = require('multer');
var flash = require('connect-flash');
var mongo = require('mongodb');
var mongoose = require('mongoose');
var db = mongoose.connection;


var routes = require('./routes/index');
var users = require('./routes/users');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');


// Handle file uploads
var multer = require('multer');
var upload = multer({ dest: './uploads' });

// uncomment after placing your favicon in /public
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));

// Handle Express Sessions
app.use(session({
    secret:'secret',
    saveUninitialized: true,
    resave: true
}));

// passport
app.use(passport.initialize());
app.use(passport.session());

// Validator
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(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));


app.use(flash());
app.use(function (req, res, next) {
  res.locals.messages = require('express-messages')(req, res);
  next();
});

app.get('*', function(req, res, next){
    res.locals.user = req.user || null;
    next();
});

app.use('/', routes);
app.use('/users', users);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  var err = new Error('Not Found');
  err.status = 404;
  next(err);
});

// error handlers

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
  app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
      message: err.message,
      error: err
    });
  });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
  res.status(err.status || 500);
  res.render('error', {
    message: err.message,
    error: {}
  });
});


module.exports = app;

最佳答案

首先,files 应该是一个数组。如果您确定只发送一个文件,请尝试使用此代码块:

  // Check for Image Field
  if(req.files && req.files[0] && req.files[0].profileimage){
      console.log('uploading File...');

      // File Info
      var profileImageOriginalName = req.files[0].profileimage.originalname;
      var profileImageName = req.files[0].profileimage.name;

      var profileImageMime = req.files[0].profileimage.mimetype;
      var profileImagePath = req.files[0].profileimage.path;
      var profileImageExt = req.files[0].profileimage.extension;
      var profileImageSize = req.files[0].profileimage.size;
  } else {
      // Set a Default Image
      var profileImageName = 'noimage.png';
  }

关于javascript - Node.js 表单验证无法读取未定义的属性 'profileimage',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55489570/

相关文章:

node.js - child_process.execSync 返回的缓冲区不完整

javascript - 如何将 app = express() 传递到另一个模块?

javascript - 将音频从 youtube 流式传输到 html 音频标签

javascript - 文本将成为 Div 背景的剪贴蒙版

php - 在单段代码中混合 PHP、Javascript、Ajax

javascript - 在同一容器中呈现内容的有效方法

javascript - 如何在 NodeJS 中调用导出函数?哪些可以嵌套?

node.js - Mongoose 返回重复结果

javascript - 在 NodeJS 上跨页面请求维护后端连接?

javascript - 从 Javascript 更改 Actionlink 参数