这可能是因为加密算法中使用的salt与比较方法中提供的salt不匹配导致的。可以尝试在比较方法中手动指定salt来解决此问题。以下是示例代码:
const bcrypt = require('bcryptjs');
const saltRounds = 10;
// 加密密码
const password = 'myPassword';
const salt = bcrypt.genSaltSync(saltRounds);
const hashedPassword = bcrypt.hashSync(password, salt);
// 比较密码
const comparePassword = 'myPassword';
const saltForCompare = bcrypt.getSalt(hashedPassword);
const isMatched = bcrypt.compareSync(comparePassword, hashedPassword, saltForCompare);
console.log(isMatched); // 输出true或false
注意:在上面的代码示例中,我们使用了genSaltSync
方法来生成一个随机salt,并将其用于加密操作。然后,我们使用getSalt
方法通过密文获取该salt。最后,我们在比较方法中使用该salt以确保比较结果正确。
希望这能解决你的问题!