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