登录
首页 >  Golang >  Go问答

Python 采用 pbkdf2 算法对密码进行哈希化

来源:stackoverflow

时间:2024-02-08 11:09:22 171浏览 收藏

大家好,我们又见面了啊~本文《Python 采用 pbkdf2 算法对密码进行哈希化》的内容中将会涉及到等等。如果你正在学习Golang相关知识,欢迎关注我,以后会给大家带来更多Golang相关文章,希望我们能一起进步!下面就开始本文的正式内容~

问题内容

我有在 golang 上实现的代码片段,运行良好

package main

import (
    "crypto/sha256"
    "encoding/hex"
    "fmt"

    "golang.org/x/crypto/pbkdf2"
)

func main() {
    newpasswd := pbkdf2.key([]byte("test"), []byte("gare5vghio"), 10000, 50, sha256.new)
    fmt.println(hex.encodetostring(newpasswd), nil)
}

我正在尝试在 python 上做同样的事情

def main():

    password = b'test'
    salt = b'gare5vghio'
    iterations = 1000

    key = pbkdf2_hmac("sha256", password, salt, iterations, 50)

    print(key)
    print(key.decode())

但是key.decode()方法抛出错误:

UnicodeDecodeError('utf-8', b'\xd9\xb2;\x0f$\x9a\x9c\t\x91\x16\x81\xb8a\x00\xd8\xdd{e.\xa9\x7f\xe9\x92dH\xa6\x05\x16\xd8\xbb\xfdy\x13\xc5D\x1c\xa2\x93e\xbf{\\\x19\xc1\x8df\xf4\xbft\xe2', 5, 6, 'invalid start byte')

我的 python 代码做错了什么?


正确答案


.decode() 正在尝试通过将字节解释为 utf-8 编码数据来从 bytes 转换为 str (您可以向其传递一个参数以使用不同的编解码器,但它的根本目的是用于转换文本的编码表示形式数据返回到 str,并且随机原始字节不是文本的编码表示)。 utf-8是一种自校验编码;随机字节很少能通过自检。

如果要将字节显示为十六进制字符串,请使用:

print(key.hex())

其中 bytes.hexbytes 方法,它直接转换为两倍长度的 str,将每个字节表示为两个十六进制字符。

在非常旧的(3.5 之前)版本的 python 上,bytes 没有 .hex() 方法,因此您需要导入 the binascii module and do

print(binascii.hexlify(key))

但这对于当前支持的任何 python 版本来说都是不必要的。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>