首页 >后端开发 >Golang >如何确保Go和Node.js之间的Bcrypt密码哈希兼容性?

如何确保Go和Node.js之间的Bcrypt密码哈希兼容性?

Linda Hamilton
Linda Hamilton原创
2024-12-03 07:30:10674浏览

How Can I Ensure Bcrypt Password Hashing Compatibility Between Go and Node.js?

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn