我有以下python代码:
with open(path_to_wordlist) as f:
for line in f:
hashedword = hashlib.md5(line).hexdigest()
if hashedword == hashed_word:
print('Your hash has been cracked! It is ' + str(line))
sys.exit()
print(hashedword)
print('"' + line + '"')
print('Your hash was not found in the wordlist.')
sys.exit()我已经检查并确认了hashlib在获取单词的md5值时是有效的,所以我无法理解为什么这不能工作。它会显示文件中的所有散列,但都会出错。这是我正在处理的文本文件。
123456
password
12345678
qwerty
123456789例如,123456是‘f447b20a7fcb53a5d5be13ea0b15af’。有人能解释一下为什么这不管用吗?
这是全部输出。记住,这些语音标记不是散列的,它们是在后面添加的,如上面所示。
f447b20a7fcbf53a5d5be013ea0b15af
"123456
"
286755fad04869ca523320acce0dc6a4
"password
"
23cdc18507b52418db7740cbb5543e54
"12345678
"
a86850deb2742ec3cb41518e26aa2d89
"qwerty
"
b2cfa4183267af678ea06c7407d4d6d8
"123456789
"我料到这是
e10adc3949ba59abbe56e057f20f883e
"123456
"
5f4dcc3b5aa765d61d8327deb882cf99
"password
"
25d55ad283aa400af464c76d713c07ad
"12345678
"
d8578edf8458ce06fbc5bb76a58c5ca4
"qwerty
"
25f9e794323b453885f5181f1b624d0b
"123456789
"发布于 2017-04-18 14:15:54
正如在comment中所暗示的,对于计算MD5哈希,每个输入行末尾的换行符(\n)是否被认为是输入的一部分是相关的。
对于f: hashedword = hashlib.md5( line ).hexdigest()中的行
在这里,line包含整行,包括换行符。
显然,您期望获得行内容的MD5,而不需要换行符。
为了实现这一点,您可以将line.rstrip('\n')而不是line传递给hashlib.md5函数。
https://stackoverflow.com/questions/43474270
复制相似问题