mysql - PassportJS MySql : do I really need to lookup database on every deserializeUser?

标签 mysql node.js passport.js koa2 koa-passport

我使用 koa-passport 进行身份验证,凭据存储在 mySQL 服务器上。每个用户名在数据库表中都有一个唯一的 ID。我使用的是一个非常简单的方案,我只使用 ID 进行序列化和反序列化,而不是使用整个用户对象。

对于身份验证,数据库中定义了一个存储过程,如果在数据库中找到提供的凭据,则返回 null 或 userID(存储过程会查看用户名和密码,因此无需在 NodeJS 上进行处理。请为简单起见,假设下面的代码片段直接为我们提供值,而不格式化 mySQL 数据库的结果)

const localStrategy = require('passport-local').Strategy;
passport.serializeUser((ctx, ID, done) => {
    done(null, ID);
});

passport.deserializeUser(async (ctx, ID, done) => {
    mySQLPool.getConnection(function (err, thisConnection) {
        let sqlQuery = "select * from table where userID = " + ID + "";
        thisConnection.query(sqlQuery, function (error, results) {
            thisConnection.release();
            console.log("De-serializing User");
            done(error, results.userID);
        })
    }) 
});

passport.use(new localStrategy({
    usernameField: 'username',
    passwordField: 'password',
    passReqToCallback: true
}, (async function (ctx, username, password, done) {
    mySQLPool.getConnection(function (err, thisConnection) {
        let sqlQuery = "CALL " + leadingSQLStoredProc + username + "', '" + password + trailingSQLStoredProc;
        console.log("Authenticating user....")
        thisConnection.query(sqlQuery, function (error, results) {
            thisConnection.release();
            if (error)
                return done(error);
            if (results.userID !== null)
                return done(null, results.userID);
            else
                return done(null, false);
        })
    })
})))

有没有办法避免在每次反序列化时访问数据库?

最佳答案

是的,您可以序列化并存储整个用户对象而不是其 ID。

但我不建议您这样做,因为 session 中的数据可能会过时。最好在每次请求时从数据库中获取它。

关于mysql - PassportJS MySql : do I really need to lookup database on every deserializeUser?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46196878/

相关文章:

php - Laravel 5.5 按票数总和获取帖子顺序

PHP PDO Mysql 未加载。 extension在extensions.ini中,php_mysql.so存在,但是phpinfo只显示sqlite和dblib

mysql - 声明......不工作的条件

javascript - 后端带有 C++ 类的 Electron nodejs

node.js - 在使用带sequelize 的 Passport 时,isAuthenticated 始终为 false

node.js - successRedirect 不适用于 Passport 登录passport-local

mysql - 如何在数据透视表中对串联和求和(不可预测的)值进行分组?

javascript - 循环 Mongoose 数据数组

javascript - jade模板系统自动隐藏div元素?

node.js - 使用我的自己的Web应用程序使用passwordjs管理单点登录-共享登录