赞
踩
python的Django框架自带了一套加密方法: make_password( ),具体作用如下:
- >>> from django.contrib.auth.hashers import make_password, check_password
-
- >>> make_password("www.baidu.com", None, 'pbkdf2_sha1')
参1: 加密的密码,参2: 任意字符串(用于固定生成的字符串,不能为空) 参3: 加密方式
得到的是一串随机字符串,并且每次生成都不一样
- >>> make_password("abcdef", None, 'pbkdf2_sha256') == make_password("abcdef", None,'pbkdf2_sha256')
- False
这时候如果需要验证密码比较是否正确就需要用check_password( ),具体如下:
- >>> text = "www.baidu.com"
- >>> passwd = make_password(text, None, 'pbkdf2_sha1')
- >>> print passwd
- pbkdf2_sha112000xzMLhCNvQbb8$i1XDnJIpb/cRRGRX2x7Ym74RNfPRCUp5pbU6Sn+V3J0=
- >>> ret = check_password(text, passwd)
- >>> print(ret)
- True
如果你不想每次都生成不同的密文,可以把make_password的第二个函数给一个固定的字符串,如下:
- >>> make_password(text,"a",'pbkdf2_sha1')
- u'pbkdf2_sha112000a5HkIPczRZGSTKUBa5uzZmRuAWdp2Qe6Oemhdasvzv4Q='
- >>> make_password(text,"a",'pbkdf2_sha1')
- u′pbkdf2_sha112000a5HkIPczRZGSTKUBa5uzZmRuAWdp2Qe6Oemhdasvzv4Q='
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。