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中文網其他相關文章!