GolangApp Engine-安全地哈希用户密码

GolangApp Engine-安全地哈希用户密码,第1张

Golang / App Engine-安全地哈希用户密码

看看go.crypto。它提供对pbkdf2和bcrypt的支持。两种实现都是用Go编写的,并且可以在GAE上正常工作。

最简单的使用方法可能是bcrypt。要运行包:

go get golang.org/x/crypto/bcrypt

用法示例

import "golang.org/x/crypto/bcrypt"func clear(b []byte) {    for i := 0; i < len(b); i++ {        b[i] = 0;    }}func Crypt(password []byte) ([]byte, error) {    defer clear(password)    return bcrypt.GenerateFromPassword(password, bcrypt.DefaultCost)}ctext, err := Crypt(pass)if err != nil {    log.Fatal(err)}fmt.Println(string(ctext))

输出将是这样的:

a$sylGijT5CIJZ9ViJsxZOS.IB2tOtJ40hf82eFbTwq87iVAOb5GL8e

如果只需要哈希,请使用pbkdf2。例:

import "golang.org/x/crypto/pbkdf2"func HashPassword(password, salt []byte) []byte {    defer clear(password)    return pbkdf2.Key(password, salt, 4096, sha256.Size, sha256.New)}pass := []byte("foo")salt := []byte("bar")fmt.Printf("%xn", HashPassword(pass, salt))


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5086668.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-16
下一篇 2022-11-16

发表评论

登录后才能评论

评论列表(0条)

保存