Я пытаюсь аутентифицировать пользователей с помощью локальной стратегии Passport. При регистрации пользователя он создается в БД, но не перенаправляется правильно. Он просто отправляет «Плохой запрос» в браузере.
То же самое происходит при входе в систему - просто «Плохой запрос». Cookie все еще создается, и пользователь фактически вошел в систему, но не перенаправлен.
Большая часть кода взята с курса Udemy, и он работает безупречно в другом проекте, который я пробовал. Это буквально тот же код.
Все пакеты npm установлены в Package.json.
Вот мой app.js:
const express = require("express");
const bodyParser = require("body-parser");
const ejs = require("ejs");
const mongoose = require("mongoose");
const session = require("express-session");
const passport = require("passport");
const passportLocalMongoose = require("passport-local-mongoose");
const app = express();
app.use(express.static("public"));
app.set("view engine", "ejs");
app.set('views', [__dirname + '/views/admin', __dirname + '/views/admin/partials', __dirname + '/views/login', __dirname + '/views/reshape']);
app.use(bodyParser.urlencoded({
extended: true
}));
app.use(session({
secret: "secret",
resave: false,
saveUninitialized: false
}));
app.use(passport.initialize());
app.use(passport.session());
mongoose.connect("mongodb://localhost:27017/userDB", {
useNewUrlParser: true
});
mongoose.set("useCreateIndex", true);
const userSchema = new mongoose.Schema({
name: String,
email: String,
password: String,
role: String,
});
userSchema.plugin(passportLocalMongoose);
const User = new mongoose.model("User", userSchema);
passport.use(User.createStrategy());
passport.serializeUser(User.serializeUser());
passport.deserializeUser(User.deserializeUser());
app.get("/", function(req, res) {
res.render("home");
});
app.get("/login", function(req, res) {
res.render("pages-login");
});
app.get("/logout", function(req, res) {
res.render("pages-logout");
});
app.get("/register", function(req, res) {
res.render("pages-register");
});
app.get("/forgot_password", function(req, res) {
res.render("pages-recoverpw");
});
app.get("/admin", function(req, res) {
if (req.isAuthenticated()) {
res.render("index");
} else
res.redirect("/login");
});
app.get("/product-keys", function(req, res) {
res.render("product-keys");
});
app.post("/register", function(req, res, next) {
User.register({
username: req.body.registerEmail,
name: req.body.registerName
}, req.body.registerPassword, function(err, user) {
if (err) {
console.log(err);
res.redirect("/register");
} else {
passport.authenticate("local")(req, res, function() {
console.log(err);
res.redirect("/admin");
});
}
});
});
app.post("/login", function(req, res) {
const user = new User({
username: req.body.loginEmail,
password: req.body.loginPassword
});
req.login(user, function(err) {
if (err) {
console.log(err);
} else {
passport.authenticate("local")(req, res, function() {
res.redirect("/admin");
});
}
});
});
app.listen(3000, function() {
console.log("Server started on 3000");
});
Буду признателен за любую помощь. Спасибо!