TypeError: Невозможно прочитать свойство '_id' неопределенного сеанса bcryptjs - PullRequest
0 голосов
/ 10 июня 2019

Я сейчас реализую часть аутентификации для своего проекта, проблема в том, что когда я закончил с кодом, который я пытался реализовать для аутентификации, я получил эту ошибку Ошибка типа: невозможно прочитать свойство '_id' из неопределенного

Я не знаю, что делать, и я знаю, что пользователь не определен, но я не знаю, каков следующий шаг, и я в основном застрял, я был бы очень признателен, если бы вы взглянули на код и Попробуй посмотреть, как это разрешимо. Я использую bcryptjs в моем контроллере аутентификации, но надеюсь, что этого кода достаточно, чтобы увидеть, что происходит, и даже решить его.

require('dotenv').config({path: "node.env"});
const path = require('path');
const express = require('express');

const bodyParser = require('body-parser');
const mongoose = require('mongoose');
const flash = require("connect-flash");

const session = require("express-session");
const MongoDBStore = require("connect-mongodb-session")(session);
const errorController = require('./controllers/error');

const mongodb_uri = process.env.MONGODB_URI;
const app = express();
const csrf = require("csurf");
const User = require("./models/user");

const store = new MongoDBStore({
    uri: mongodb_uri,
    collection: "sessions"
});

const csrfProtection = csrf();


app.set('view engine', 'ejs');
app.set('views', 'views');

const adminRoutes = require("./routes/admin");
const blogRoutes = require("./routes/blog");
const authRoutes = require("./routes/auth");


app.use(bodyParser.urlencoded({
    extended: true
}));

app.use(express.static(path.join(__dirname, 'public')));


app.use(
    session({
        secret: process.env.SECRET,
        cookie: {
            maxAge: 1000 * 60 * 60 * 24 * 7
        },
        store: store,
        resave: false,
        saveUninitialized: false,

    })
)

app.use(flash());
app.use(csrfProtection);

app.use((req, res, next) => {
    if (!req.session.user._id) {
        return next();
    }
    User.findById(req.session.user._id)
    .then(user => {
        req.user = user;
        next();
    })
    .catch(err => console.log(err));
})

app.use((req, res, next) => {
    res.locals.isauthenticated = req.session.isLoggedIn;
    res.locals.csrfToken = req.csrfToken();
    next();
});

app.use("/admin", adminRoutes);
app.use(blogRoutes);


app.use(errorController.get404);

mongoose.set('useCreateIndex', true);

mongoose.connect(mongodb_uri, {
    useNewUrlParser: true
});

app.listen(3000, function () {
    console.log("listening to port 3000")
})

Я ожидаю, что все сработает, и я не совсем понимаю, в чем проблема, я даже следовал структуре инструктора курса.

1 Ответ

0 голосов
/ 10 июня 2019

Ваш код:

app.use((req, res, next) => {
   if (!req.session.user._id) {
       return next();
   }
   User.findById(req.session.user._id)
   .then(user => {
       req.user = user;
       next();
   })
   .catch(err => console.log(err));
})

Что вы намеревались сделать на самом деле:


app.use((req, res, next) => {
  if (!req.session.user) {
    return next();
  }
  User.findById(req.session.user._id)
    .then(user => {
      if (!user) {
        return next();
      }
      req.user = user;
      next();
    })
    .catch(err => console.log(err));
});

Вы должны сначала проверить req.session.user (удалить ._id).
Тогда вы забыли проверить .then(user => {...}), чтобы снова найти user,
то есть:
if(!user){return next();}

...