首頁 >後端開發 >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