我有点困惑,加密函数的参数是一个字符串。我是否应该简单地用 str() 包装非字符串参数,例如
hashlib.sha256(str(user_id)+str(expiry_time))
hmac.new(str(random.randbits(256)))
(暂时忽略 random.randbits() 可能在密码学上不好)。编辑:我意识到 hmac 示例很愚蠢,因为我没有将密钥存储在任何地方!
我有点困惑,加密函数的参数是一个字符串。我是否应该简单地用 str() 包装非字符串参数,例如
hashlib.sha256(str(user_id)+str(expiry_time))
hmac.new(str(random.randbits(256)))
(暂时忽略 random.randbits() 可能在密码学上不好)。编辑:我意识到 hmac 示例很愚蠢,因为我没有将密钥存储在任何地方!
好吧,通常散列函数(通常是加密函数)对字节起作用。Python 字符串基本上是字节字符串。如果要计算某个对象的哈希值,则必须将其转换为字符串表示形式。如果您想检查哈希是否正确,请确保稍后应用相同的操作。并确保您的字符串表示不包含任何您不想检查的更改数据。
编辑:由于受欢迎的请求,一个简短的提醒,Python unicode 字符串不包含字节,而是 unicode 代码点。每个 unicode 代码点包含多个字节(2 或 4,取决于 Python 解释器的编译方式)。Python 字符串只包含字节。所以 Python 字符串(类型str)是最类似于字节数组的类型。
你可以。
但是,对于 HMAC,您实际上希望将密钥存储在某处。没有密钥,您以后无法验证哈希值。:-)
哦,Sha256 并不是真正的工业强度加密功能(尽管不幸的是它在许多网站上都非常普遍地使用)。这不是保护密码或其他关键数据的真正方法,但足以生成临时令牌
编辑:如前所述,Sha256 至少需要一些盐。没有盐,Sha256 被字典攻击(时间方面)破解的门槛很低,而且还有很多 Rainbow 表可供使用。就我个人而言,我不会使用比 Blowfish 更少的密码(但那是因为我很偏执)