如何使用 SQL Server 配置 Passportjs?

Mel*_*goV 5 sql-server node.js express passport.js

我正在编写一个基于SQL Server、ExpressJs、NodeJS、AngularJs 的应用程序,我是一个快速初学者,我需要处理会话,所以我一直在考虑 PassportJs,我找不到将 SQL Server 与 PassportJs 集成的文档,所以我很困惑,我一直在尝试,但我还没有明白,我已经用express-generator构建了我的应用程序,所以这是我的app.js

护照要求:

var passport = require('passport');
var LocalStrategy = require('passport-local').Strategy;
var session = require('express-session');
Run Code Online (Sandbox Code Playgroud)

路线:

var routes = require('./routes/index');
var login = require('./routes/login');
Run Code Online (Sandbox Code Playgroud)

快速会话:

app.use(session({secret: 'xXxXxXXxX'}));

app.use(passport.initialize());
app.use(passport.session());

app.use('/', routes);
app.use('/login', login);
Run Code Online (Sandbox Code Playgroud)

护照初始化:

var initPassport = require('./r12_modulos/sesion/passport-init.js');
initPassport(passport);
Run Code Online (Sandbox Code Playgroud)

这就是我所拥有的passport-init.js

var conex = require('../conexion_bd/conex_mssql.js');
var passport = require('passport');
var LocalStrategy = require('passport-local').Strategy;

module.exports = function () {

passport.serializeUser(function (user, done) {
    console.log('serializing user:', user.username);
    done(null, user.username);
});

passport.deserializeUser(function (username, done) {
    done(null,username);
});

passport.use('login', new LocalStrategy({
    passReqToCallback: true
},
    function (req, username, password, done) {

        var _cParameters = [];
        _cParameters.push({ name: 'usuario', type: 'VarChar', value: username });
        _cParameters.push({ name: 'password', type: 'NVarChar', value: password });

        conex.sp_recordset(conex.mssql_conect, 'dbo.sp_sis_loginR12', _cParameters, function (data) {
            if (data[0].response == 1) {
                return done(null, data[0].usuario);
            }
            else {
                return done(null, false);
            }
        });

    }
    ));
};
Run Code Online (Sandbox Code Playgroud)

正如你所看到的,我编写了一个模块来执行SQL Server存储过程,当我在互联网上搜索passportjs通常与Mongo集成时,我不知道如何使用SQL Server处理这些功能passport.serializeUserpassport.deserializeUser

这就是我在路线中所拥有的login.js

var express = require('express');
var passport = require('passport');
var router = express.Router();

router.post('/', passport.authenticate('login', {
    successRedirect: '/',
    failureRedirect: '/login'
}));

module.exports = router;
Run Code Online (Sandbox Code Playgroud)

当我发送 post 请求时,服务器不会返回错误,但不会运行我的 LocalStrategy。

Mel*_*goV 2

谷歌搜索我发现这篇文章Understanding Passport.jsauthentication flow,正如链接所说,作者解释了这是passportJs流程,我有一些错误,除非您定义用户名和密码字段的名称,否则您必须在帖子中发送它们像这样req.body.usernamereq.body.password这是我的错误之一,我以这种方式处理序列化和反序列化函数:

序列化用户函数

passport.serializeUser(function (user, done) {
    console.log('serializing user:', user);
    done(null, user);
});
Run Code Online (Sandbox Code Playgroud)

反序列化用户函数

passport.deserializeUser(function (username, done) {
    console.log('deserializing user:', username);
    done(null,username);
});
Run Code Online (Sandbox Code Playgroud)