Go와 Node.js 간의 Bcrypt 비밀번호 해싱 호환성
Node.js에서 Go로 마이그레이션할 때 이전 버전과의 호환성을 유지하는 것이 필수적입니다. 사용자 비밀번호가 데이터베이스에 저장되어 있습니다. 이를 위해서는 Go에서 Node.js의 bcrypt 비밀번호 해싱 기능을 복제해야 합니다.
Node.js에서 bcrypt 암호화 코드는 bcrypt 라이브러리를 활용하여 사용자 비밀번호에서 솔트 처리된 해시를 생성합니다. golang.org/x/crypto/bcrypt 패키지를 사용하는 Go의 해당 코드는 다음과 같습니다.
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!