node.js使用sqlite进行护照身份验证

时间:2014-05-05 21:01:47

标签: node.js sqlite passport.js

可能使用node.js + passport和sqlite数据库进行会话吗?所有示例仅与mongoDb一起使用。我想收集sqlite中的所有数据。

2 个答案:

答案 0 :(得分:15)

以下是使用passport-local创建SQLite支持login strategy的示例。已省略Express特定初始化。

此示例假定您拥有一个包含以下用户表的数据库:

CREATE TABLE "users" (
    "id" INTEGER PRIMARY KEY AUTOINCREMENT,
    "username" TEXT,
    "password" TEXT, -- sha256 hash of the plain-text password
    "salt" TEXT -- salt that is appended to the password before it is hashed
)
var crypto = require('crypto');
var sqlite3 = require('sqlite3');

var db = new sqlite3.Database('./database.sqlite3');

// ...

function hashPassword(password, salt) {
  var hash = crypto.createHash('sha256');
  hash.update(password);
  hash.update(salt);
  return hash.digest('hex');
}

passport.use(new LocalStrategy(function(username, password, done) {
  db.get('SELECT salt FROM users WHERE username = ?', username, function(err, row) {
    if (!row) return done(null, false);
    var hash = hashPassword(password, row.salt);
    db.get('SELECT username, id FROM users WHERE username = ? AND password = ?', username, hash, function(err, row) {
      if (!row) return done(null, false);
      return done(null, row);
    });
  });
}));

passport.serializeUser(function(user, done) {
  return done(null, user.id);
});

passport.deserializeUser(function(id, done) {
  db.get('SELECT id, username FROM users WHERE id = ?', id, function(err, row) {
    if (!row) return done(null, false);
    return done(null, row);
  });
});

// ...

app.post('/login', passport.authenticate('local', { successRedirect: '/good-login',
                                                    failureRedirect: '/bad-login' }));

答案 1 :(得分:0)

您现在可能已经知道了,但是对于其他人,您可以使用此行。 const LocalStrategy = require('passport-local')。Strategy