MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

Como armazenar criptografia pbkdf2 no ​​mongoDB?


Armazenar o hash como uma string hexadecimal no banco de dados funciona bem para mim (armazená-los 'raw' em um String ou um Buffer propriedade não):
var crypto      = require('crypto');
var mongoose    = require('mongoose');
var client      = mongoose.connect('mongodb://localhost/test');
var UserSchema  = new mongoose.Schema({
  salt  : String,
  hash  : String
});

var User = mongoose.model('User', UserSchema);

hash('secret', function(err, salt, key) {
  new User({ salt : salt, hash : key.toString('hex') }).save(function(err, doc) {
    User.findById(doc._id, function(err, doc) {
      hash('secret', doc.salt, function(err, key) {
        console.log('eq', doc.hash === key.toString('hex'));
      });
    });
  });
});

(a propósito, tanto crypto.pbkdf2 e crypto.randomBytes têm contrapartes síncronas)