- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
实现 Passport.js 进行身份验证时遇到错误。 session 集合有数据解析,但是,我收到此错误:
TypeError: Cannot read properties of undefined (reading 'initialize')
at Authenticator.initialize (\server\node_modules\passport\lib\authenticator.js:130:26)
at Layer.handle [as handle_request] (\server\node_modules\express\lib\router\layer.js:95:5)
at trim_prefix (\server\node_modules\express\lib\router\index.js:317:13)
at \server\node_modules\express\lib\router\index.js:284:7
at Function.process_params (\server\node_modules\express\lib\router\index.js:335:12)
at next (\server\node_modules\express\lib\router\index.js:275:10)
at session (\server\node_modules\express-session\index.js:479:7)
at Layer.handle [as handle_request] (\server\node_modules\express\lib\router\layer.js:95:5)
at trim_prefix (\server\node_modules\express\lib\router\index.js:317:13)
at \server\node_modules\express\lib\router\index.js:284:7
我的index.js 文件包含以下内容:
// Route Variables
const loginRoute = require("./routes/api/login");
/*
==MIDDLEWARE==
*/
// Express Parsing Middleware
app.use(express.json());
app.use(express.urlencoded({ extended: true }));
// Passport Auth Middleware
require("./config/passport");
/*
==SESSION SETUP==
*/
const sessionStore = MongoStore.create({
mongoUrl: process.env.MONGO_URL,
});
app.use(
session({
secret: process.env.SECRET,
resave: false,
saveUninitialized: true,
store: sessionStore,
cookie: {
maxAge: 1000 * 60 * 60 * 24,
},
})
);
// Initialize Passport and Use Session for Serialize/Deserialization
app.use(passport.initialize);
app.use(passport.session());
/*
==ROUTES==
*/
// User Route
app.use("/api", loginRoute);
当路由到/api/login
时,登录文件包含以下内容:
const router = require("express").Router();
var passport = require("passport");
router.post(
"/login",
passport.authenticate("local", {
failureRedirect: "/login",
successRedirect: "/dashboard",
})
);
module.exports = router;
最后,我的 Passport 中间件文件:
const passport = require("passport");
const LocalStrategy = require("passport-local").Strategy;
const bcrypt = require("bcrypt");
const User = require("../models/User");
const verifyCallback = (username, password, done) => {
User.findOne({ username: username })
.then((user) => {
if (!user) {
return done(null, false);
}
// Validate Password
bcrypt.compare(password, user.password).then((isMatch) => {
if (isMatch) {
return cb(null, user);
} else {
return cb(null, false);
}
});
})
.catch((err) => {
done(err);
});
};
const strategy = new LocalStrategy(verifyCallback);
passport.use(strategy);
passport.serializeUser((user, done) => {
done(null, user.id);
});
passport.deserializeUser((userId, done) => {
User.findById(userId)
.then((user) => {
done(null, user);
})
.catch((err) => done(err));
});
这似乎是我不知道它来自何处或击中何处的错误之一。当点击登录表单的提交按钮时,它只会抛出错误。除此之外,它初始化得很好。我查看了 Passport.js 文档,一切都按其应有的顺序进行。
我的前端在点击提交按钮时调用此函数:
const handleOnSubmit = (e) => {
e.preventDefault();
login(data)
.then((response) => {
toast.success(response.data.message);
setData({ username: "", password: "" });
navigate("/dashboard");
})
.catch((err) => {
if (err.response) {
toast.error(err.response.data.message);
} else if (err.request) {
toast.error(err.request);
} else {
toast.error(err.message);
}
});
};
并且从我前端的loginAPI.js 文件调用登录函数,其中包含以下内容:
const instance = axios.create({
baseURL: "http://localhost:8000/api/",
timeout: 1000,
});
export async function login(data) {
if (!data.username || !data.password) {
return Promise.reject(new Error("Data is missing"));
}
return await instance.post("/login", data);
}
最佳答案
问题出在 index.js 中的这一行:
app.use(passport.initialize);
您应该调用函数initialize()
和不属性initialize
。像这样更改您的代码:
app.use(passport.initialize());
关于javascript - Passport JS 无法读取未定义的属性(读取 'initialize' ),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69982445/
已经为此工作了几个小时,非常令人沮丧...... router.post('/', passport.authenticate('local-signup', function(err, user,
我正在寻找一种方法让我的客户端使用 facebook JS SDK 进行授权,然后以某种方式将此授权传输到我的 Node 服务器(以便它可以使用 fb graph api 验证请求) 我偶然发现: h
passport.socketio 抛出此错误,同时无法授权用户。 Error: Error: Failed to deserialize user out of session 我已将问题范围缩小到
passport.js 函数passport.serializeUser 和passport.serializeUser 有什么作用?这是维基百科中描述的序列化示例:http://en.wikiped
现代 Passport 和身份证的底部带有machine-readable zone (MRZ),其中包含基本标识信息(可能是OCR友好格式)。 机读区的格式指定了check digits的数量,可帮
我尝试对我的应用程序实现 passport 身份验证策略,但在尝试登录后不断收到以下错误: TypeError: passport.authenticate is not a function at
我正在将 passport 与 loopback 集成,并且工作正常,问题是如何获取访问 token 。 我有一个 web 应用程序(服务于与环回不同的服务器)所以: 发出请求(在环回后端) 这会将我
我使用带有passport-saml 策略 的 Passport 。在策略 上,有一个我想使用的函数。我知道策略是这样使用的: const SamlStrategy = require('passpo
这是我的套接字配置: // set authorization for socket.io io.set('authorization', passportSocketIo.authorize
我是 Passport.js 的新手。我一直在关注以下博客来注册用户 https://scotch.io/tutorials/easy-node-authentication-setup-and-lo
Passport 似乎是简单例份验证、不显眼且不难设置的绝佳选择。我正在构建一个使用 JWT 进行身份验证的 MEAN 堆栈,因此我查看了 Passport JWT。然而,有几件事我很困惑。 1) 假
我已经开始开发一个小项目,在客户端使用 React 和 Redux,后端是用 Node、Express 和 Passport.js 完成的我将尽力描述我几个小时以来所苦苦挣扎的事情。身份验证后,当用户
我正在使用 Passport 本地策略和 Passport Mongoose 本地来创建用户并检查用户身份验证。但是,我想探索使用电子邮件而不是用户名的选项。我按照文件的规定进行操作,但我未经授权。有
我正在使用 Passport 本地策略进行身份验证。在我的快速服务器中,我收到一个注册帖子请求,我应该为新用户将密码保存到数据库。但是我需要在保存到数据库之前对密码进行哈希处理。 但我不确定如何对其进
我正在将 node 与 express + mongoose 一起使用,并尝试将 passport.js 与 restful api 一起使用。 身份验证成功后,我不断收到此异常(我在浏览器上看到回调
我正在尝试在 JWTStrategy 中检查列入黑名单的 JWT token 。 jwtFromRequest 没有采用异步函数,所以我无法在那里检查它。 validate 函数提供对 JWT 负载而
目前,我正在通过 Google 构建登录功能,但我遇到了一些让我感到困惑的问题。 我们可以在一个项目中同时使用 Restful API 和 Graphql API 吗?除了谷歌身份验证,我们需要一些路
我正在使用与 express 配合良好的 Passport 本地策略: passport.use(localStrategy); passport.serializeUser((user, done)
我正在尝试通过passport-facebook 对用户进行身份验证,并且发生了一件非常奇怪的事情,我真的不确定。定义我的路线时,我有这行代码 app.get('/login/facebook',
当我使用 NPM 包“passport-azure-ad”尝试连接到 Azure AD 时,出现以下错误。我已成功连接到 Facebook、Google 和 MSFT Live,成功,但无法弄清楚为什
我是一名优秀的程序员,十分优秀!