Rumah >pembangunan bahagian belakang >Golang >Bagaimanakah Saya Boleh Memastikan Keserasian Pencapaian Kata Laluan Bcrypt Antara Go dan Node.js?
Keserasian Pencincangan Kata Laluan Bcrypt antara Go dan Node.js
Dalam berhijrah dari Node.js ke Go, adalah penting untuk mengekalkan keserasian ke belakang dengan kata laluan pengguna yang disimpan dalam pangkalan data. Ini memerlukan replikasi fungsi pencincangan kata laluan bcrypt Node.js dalam Go.
Dalam Node.js, kod penyulitan bcrypt menggunakan perpustakaan bcrypt untuk menjana cincang masin daripada kata laluan pengguna. Kod yang setara dalam Go, menggunakan pakej golang.org/x/crypto/bcrypt, ialah:
hashedPassword, err := bcrypt.GenerateFromPassword(password, bcrypt.DefaultCost)
Fungsi ini menghasilkan rentetan kata laluan cincang yang serasi dengan output yang dihasilkan oleh kod Node.js.
Contoh Go yang berfungsi berikut menunjukkan proses pencincangan kata laluan 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.") } }
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Memastikan Keserasian Pencapaian Kata Laluan Bcrypt Antara Go dan Node.js?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!