#题目要求:
#生成 0~999999 所有整数组成密码的哈希值
#将上面生成的哈希值保存为映射类型
#通过查表的方式,计算下面 3 个哈希值对应的明文密码#友情提示:hashlib.md5() 的参数是需要一个 b 字符串(即 bytes 类型的对象),这里可以使用 bytes("123", "utf-8") 的方式将 "123" 转换为 b"123"。import hashlibrainbow_table = {}for i in range(1000000):bstr = bytes(str(i), "utf-8")s = hashlib.md5(bstr).hexdigest()rainbow_table[s] = is1 = "021bbc7ee20b71134d53e20206bd6feb"s2 = "e10adc3949ba59abbe56e057f20f883e"s3 = "655d03ed12927aada3d5bd1f90f06eb7"print(f"{s1} 对应的明文是:{rainbow_table[s1]}")print(f"{s2} 对应的明文是:{rainbow_table[s2]}")print(f"{s3} 对应的明文是:{rainbow_table[s3]}")
为啥上面代码里bstr = bytes(str(i), "utf-8"),str(i)不用str就会报错,用“i”也不行。
在这段代码中,`str(i)` 的作用是将整数 `i` 转换成字符串。这是因为 `hashlib.md5()` 函数需要接收一个字节串(`bytes` 类型)作为输入。而 `i` 是一个整数,它不能直接传递给 `hashlib.md5()`,需要先将其转换成字符串形式,再将字符串转换为字节串。
具体的步骤是:
1. `str(i)`:将整数 `i` 转换为字符串(例如 `i = 5` 转换成 `"5"`)。
2. `bytes(str(i), "utf-8")`:将字符串 `"5"` 转换为 UTF-8 编码的字节串(例如 `"5"` 转换成 `b"5"`),这是因为 `hashlib.md5()` 函数要求输入必须是字节串。
如果不使用 `str(i)`,直接使用 `i`,会导致类型错误,因为 `hashlib.md5()` 无法处理整数类型。通过将 `i` 转换为字符串并进一步转换为字节串,就可以正确计算 MD5 哈希值。
总结一下:`str(i)` 主要是为了将整数 `i` 转换成字符串,然后再转换为字节串,确保能够传递给 `hashlib.md5()`。
你提到的“用双引号解决”可能是指直接使用双引号包裹一个数字,比如 "i",而不是 str(i)。但实际上,双引号包裹的 "i" 是一个字符串字面量,表示的是字符 'i',而不是数字 i。
为什么不能直接使用 "i"?
如果你写成:
bstr = bytes("i", "utf-8")
这将会创建一个字节串 b"i",它代表的是字符 'i' 的 UTF-8 编码,而不是数字 i 的 UTF-8 编码。这样就和你的需求不匹配,因为 i 是一个整数,而你需要的是将这个整数转换成对应的字符串形式,再转成字节串。
正确的方式:
bstr = bytes(str(i), "utf-8")
str(i) 将整数 i 转换成字符串(比如 i = 5 时,str(5) 就是 "5")。
然后通过 bytes(str(i), "utf-8") 将这个字符串转换成字节串(b"5")。
这个过程确保了 i 转换成字符串后,再转化为字节串,进而计算 MD5 哈希值。
总结:
"i" 是字符串字面量 'i',表示的是字符 'i',而不是数字 i。
str(i) 是将数字 i 转换为字符串(如 "5"),然后再转成字节串传给 hashlib.md5()。
因此,必须使用 str(i),而不能简单地用双引号包裹 i。