每次服务器重新启动时,哈希模式都会更改

时间:2018-12-03 06:15:33

标签: node.js hash bcrypt

我有一个表格,其中有两列:许可证已激活

我存储的许可证代码不是纯文本,而是散列的。我正在使用bcrypt模块来生成带有盐回合10的哈希。当我在数据库中搜索许可证时会发生问题。要搜索许可证,我首先生成许可证的哈希,然后搜索数据库。在重新启动服务器之前,它可以正常工作。

服务器重新启动时,它将为相同的许可证代码生成不同的哈希字符串。有没有什么办法解决这一问题?每当服务器重新启动时,如何停止更改相同许可证代码的哈希模式?

1 个答案:

答案 0 :(得分:1)

问题在于盐和使用bcrypt的方式。 您正在使用saltRounds生成新的salt(随机值),因此哈希值始终是不同的。 如果使用固定的salt值,则哈希将相同。请参见下面的示例:

        const bcrypt = require('bcrypt');
        const saltRounds = 10;
        const myPlaintextPassword = 's0/\/\P4$$w0rD';
        const someOtherPlaintextPassword = 'not_bacon';

        bcrypt.genSalt(saltRounds, function(err, salt) {
            console.log('new salt:%s',salt);
            bcrypt.hash(myPlaintextPassword, salt, function(err, hash) {
                // Store hash in your password DB.
                console.log('new hash:%s',hash);
            });
        })
        //first time generated values were below, but each run will generate new values:
        //salt:$2b$10$X4kv7j5ZcG39WgogSl16au
        //hash:$2b$10$X4kv7j5ZcG39WgogSl16aupL0..j8Fmm8Lwgq92uWuM5KyXhE6tpO

        //Generate the same hash value as fixed salt value is used
        salt = '$2b$10$X4kv7j5ZcG39WgogSl16au'
        bcrypt.hash(myPlaintextPassword, salt, function(err, hash) {
            console.log('same value:%s', hash); //hash:$2b$10$X4kv7j5ZcG39WgogSl16aupL0..j8Fmm8Lwgq92uWuM5KyXhE6tpO
        });

        // Test comparison
        hash='$2b$10$X4kv7j5ZcG39WgogSl16aupL0..j8Fmm8Lwgq92uWuM5KyXhE6tpO' //first hash of myPlaintextPassword
        bcrypt.compare(myPlaintextPassword, hash, function(err, res) {
            console.log('Test using the correct password/key - should authenticate');
            if (res === true) {
                console.log('authenticated ');
            } else {
                console.log('NOT authenticated');
            }
        });
        bcrypt.compare(someOtherPlaintextPassword, hash, function(err, res) {
            console.log('Test using an incorrect password/key - should fail authentication');
            if (res === true) {
                console.log('authenticated');
            } else {
            console.log('NOT authenticated');
            }
        });

也许使用其他一些值作为主密钥(许可证号),并使用一些加密的值来表明它是否是有效许可证。