newUser появится не определено - PullRequest
0 голосов
/ 21 ноября 2018

Я новичок в Express и пытаюсь создать простую форму авторизации / регистрации."newUser" выходит неопределенным, и я не совсем уверен, почему .... любые предложения очень ценятся.Спасибо!

bcrypt.hash(newUser.password, salt, function(err, hash) {

let express = require("express");
let router = express.Router();
let mongojs = require("mongojs");
let db = mongojs("carapp", ["users"]);
let bcrypt = require("bcryptjs");
let passport = require("passport");
let LocalStrategy = require("passport-local").Strategy;

// login GET PAGE
router.get("/login", function(req, res) {
res.render("login");
});

// Register GET PAGE
router.get("/register", function(req, res) {
  res.render("register");
});
// Register POST
router.post("/register", function(req, res) {
  let name = req.body.name;
  let email = req.body.email;
  let username = req.body.username;
  let password = req.body.password;
  let confirm_password = req.body.confirm_password;

  // Validation
  req.checkBody("name", "Name field is required").notEmpty();
  req.checkBody("email", "Email field is required").notEmpty();
  req.checkBody("email", "Please use a Valid Email Address").isEmail();
  req.checkBody("username", "Username field is required").notEmpty();
  req.checkBody("password", "Password field is required").notEmpty();
  req.checkBody("confirm_password", "Passwords Do Not 
  Match".equals(req.body.password);

  // Check For Errors

  let errors = req.validationErrors();
  if (errors) {
    console.log("Form has errors");
    res.render("register", {
      errors: errors,
      name: name,
      email: email,
      username: username,
      password: password,
      confirm_password: confirm_password
    });
  } else {
    let newUser = {
      name: name,
      email: email,
      username: username,
      password: password
    };
  }

  bcrypt.genSalt(10, function(err, salt) {
    bcrypt.hash(newUser.password, salt, function(err, hash) {
      newUser.password = hash;

  db.users.insert(newUser, function(err, doc) {
    if (err) {
      res.send(err);
    } else {
      console.log("User Added. Good JOB using MONGODB Matt!");
      req.flash("success", "You are registered and can log in");
      res.location("/");
      res.redirect("/");
    }
  });
});
});

  passport.serializeUser(function(user, done) {
    done(null, user._id);
  });

  passport.deserializeUser(function(id, done) {
    db.users.findOne({ _id: mongojs.OnjectId(id) }, function(err, user{
   done(err, user);
    });
  });

  passport.use(
new LocalStrategy(function(username, password, done) {
  db.users.findOne({ username: username }, function(err, user) {
    if (err) {
      return done(err);
    }
    if (!user) {
      return done(null, false, { message: "Incorrect Username" });
    }

    bcrypt.compare(password, user.password, function(err, isMatch) {
      if (err) {
        return done(err);
      }
      if (isMatch) {
        return done(null, user);
      } else {
        return done(null, false, { message: "Incorrect Password" });
      }
    });
  });
})
);

  // Login Post
  router.post("/login",passport.authenticate("local",{
    successRedirect: "/",
    failureRedirect: "/users/login",
    failureFlash: "Invalid Username or Password"
  } +
    function(req, res) {
      console.log("Auth Successful");
      res.redirect("/");
        }
    )
  );
});
module.exports = router; //brackets needed here

Вот мой файл package.json

 {
  "name": "cars",
  "version": "1.0.0",
  "description": "car buying application",
  "main": "app.js",
  "scripts": {
   "start" : "nodemon"
  },
 "author": "",
  "license": "ISC",
  "dependencies": {
  "bcryptjs": "^2.4.3",
  "body-parser": "^1.18.3",
  "bootstrap": "^4.1.3",
  "connect-flash": "^0.1.1",
  "ejs": "^2.6.1",
  "express": "^4.16.4",
  "express-messages": "^1.0.1",
  "express-session": "^1.15.6",
   "mongojs": "^2.6.0",
   "passport": "^0.4.0",
   "passport-local": "^1.0.0",
   "pug": "^2.0.3"
  }
 }

Ответы [ 2 ]

0 голосов
/ 21 ноября 2018

let существует только в области видимости его блока .

Когда вы объявляете его в блоке {}, но немедленно закрываете блок, это фактически неоперация.

В исходном коде:

  // newUser = undefined
  } else {
    let newUser = {
      name: name,
      email: email,
      username: username,
      password: password
    };
    // newUser = Object
  }
  // newUser = undefined

Вы можете попробовать что-то вроде:

 let newUser;
 // newUser = undefined
 ....
  } else {
    newUser = {
      name: name,
      email: email,
      username: username,
      password: password
    };
    // newUser = Object
  }
  // newUser = Object
0 голосов
/ 21 ноября 2018

Убедитесь, что у вас установлен body-parser.Ваше тело может быть не в формате JSON.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...