我试图了解 linux 影子字符串格式,并将字符串转换为一般的十六进制格式,就像 MD5 通常的表示方式一样。
我在这里遵循定义 http://www.akkadia.org/drepper/SHA-crypt.txt
如上所述,最后一步(步骤 22)是特殊的 base-64 编码,具有重新排序的字节。
我写了一个python脚本(我的第一个python程序)来解码base64然后把它放回原来的顺序。
但问题是,结果与通常的 SHA1 哈希值不同。
例如,带有盐“456”的密码“123”(不带引号)将产生一个影子字符串
$6$456$yTSeWYNbvZDCsuZIN.Qdeg.0DxY5N1XddpO7qgFqjnZOqpy5QXIeMM7pdQYWIgu6Y3pSh5eYqJ21fqrlrjhJe/
使用我的程序,它会生成
A922F952190B1ED9ADD9EFEDA918472364A10CABDBE79D7B5EA52A4FA6691B6A7648D429AB7BED45C7F7FE9938B8C0084F3025365C1FDC968A145192767D566A
但是 123456 和 456123 的 SHA512 哈希是
BA3253876AED6BC22D4A6FF53D8406C6AD864195ED144AB5C87621B6C233B548BAEAE6956DF346EC8C17F5EA10F35EE3CBC514797ED7DDD3145464E2A0BAB413
CA3D1DDE02C4B15D2E95521E259C5E08AAEA8FEAA722BA14014605249EFE3F248DB3D98AA7C4ACCBE887E1B40573D7EBA71017C5DF029C16C8D6F06B0FFDA310
它们都与我的结果不同。那么,我对阴影生成方法有什么理解错误吗?还是我的代码有问题?
我的python代码(输入应该是base64代码,即影子字符串的最后一个“$”之后的字符串):
#!/usr/bin/python
# filename: conv.py
import sys
b64s = "./0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"
bm = ( \
(0,21,42), \
(22,43,1), \
(44,2,23), \
(3,24,45), \
(25,46,4), \
(47,5,26), \
(6,27,48), \
(28,49,7), \
(50,8,29), \
(9,30,51), \
(31,52,10), \
(53,11,32), \
(12,33,54), \
(34,55,13), \
(56,14,35), \
(15,36,57), \
(37,58,16), \
(59,17,38), \
(18,39,60), \
(40,61,19), \
(62,20,41), \
('*','*',63))
sd_str = raw_input('Enter a Shadow String: ')
ba = [0]*64
ba_org = [0]*64
for i in range (0,21):
byte24 = 0
for j in range(0,4):
byte24 += (b64s.find(sd_str[i*4+j]) << (j*6))
for j in range(0,3):
ba[bm[i][2-j]] = ((byte24>>(j*8))&0x0000FF)
byte24 = b64s.find(sd_str[84]) + (b64s.find(sd_str[85])<<6)
ba[63] = byte24 #last byte
for i in range (0,64):
sys.stdout.write('%02X' % ba[i])
sys.stdout.write('\n')
sys.stdout.flush()