Go 和 Node.js 之间的 Bcrypt 密码哈希兼容性
从 Node.js 迁移到 Go 时,保持向后兼容性至关重要用户密码存储在数据库中。这需要在 Go 中复制 Node.js 的 bcrypt 密码哈希功能。
在 Node.js 中,bcrypt 加密代码利用 bcrypt 库从用户密码生成加盐哈希。 Go 中使用 golang.org/x/crypto/bcrypt 包的等效代码为:
hashedPassword, err := bcrypt.GenerateFromPassword(password, bcrypt.DefaultCost)
此函数生成与 Node.js 代码生成的输出兼容的哈希密码字符串。
以下 Go 工作示例演示了 bcrypt 密码哈希过程:
package main import ( "golang.org/x/crypto/bcrypt" "fmt" ) func main() { password := []byte("SomeSecretPassword") hashedPassword, err := bcrypt.GenerateFromPassword(password, bcrypt.DefaultCost) if err != nil { panic(err) } fmt.Println(string(hashedPassword)) err = bcrypt.CompareHashAndPassword(hashedPassword, password) if err == nil { fmt.Println("Password matches hash.") } else { fmt.Println("Password does not match hash.") } }
以上是如何确保Go和Node.js之间的Bcrypt密码哈希兼容性?的详细内容。更多信息请关注PHP中文网其他相关文章!