我正在尝试生成加密的密码字符串,类似于Linux中的/ etc / shadow。出于某种原因,我得到的输出是不同的。任何想法我缺少什么,是一个比另一个更长(不计算盐部分)?
#!/usr/bin/python
import crypt
alg = 6 # SHA512
salt = 'vb1tLY1qiY'
word = 'password'
insalt = '${}${}$'.format(alg, salt)
cryptWord = crypt.crypt(word, insalt)
print cryptWord
输出为:$6FMi11BJFsAc
如果我在Linux中生成这样的:
mkpasswd --method=sha-512 --salt=vb1tLY1qiY password
输出为:$6$vb1tLY1qiY$WFHTa6CRShEuKg63vuPTYOVRK1oQiM6johIEs2JslF1904VhEdSXlHje74eB4uLXHrKNyZ4bPjSlWpZD6qIo71
答案 0 :(得分:0)
我能够使用passlib。它不是作为python的一部分安装的(至少在OS X上),但是,你可以通过pip安装它。
sudo easy_install pip
pip install passlib
python -c "from passlib.hash import sha512_crypt; import getpass,string,random; print sha512_crypt.using(salt=''.join([random.choice(string.ascii_letters + string.digits) for _ in range(16)]),rounds=5000).hash(getpass.getpass())"
https://gist.github.com/hbeatty/25db5847e7068335681db88248d0deaf