利用Python 生成hash值

如果在Python中需要对用户输入的密码或者其他内容进行加密,首选的方法是生成hash值。
在Python中可以利用二个模块来进行:
- crypt
- hashlib

二、crypt (一)crypt的主要方法和常量 名称类型描述
crypt(…)   方法   对指定内容进行hash加密  
methods(…)   方法   返回可以用到的加密算法  
mksalt(…)   方法   根据加密算法生成salt  
methods(…)   方法   返回可用加密算法的列表  
METHOD_MD5   常量   md5加密算法  
METHOD_SHA256   常量   sha256加密算法  
METHOD_SHA512   常量   sha512加密算法  
(二)使用说明与示例

使用crypt.crypt(…)进行hash加密的时候,需要提供二个参数:
- 加密内容
- salt

如果不特别指定salt,系统就会调用crypt.mksalt(…)生成一个salt

如果想要以特定的加密算法生成salt就应该使用下面的命令:

>>>salt = crypt.mksalt(crypt.METHOD_SHA512) >>> salt '$6$s8Q3eNP6urKZb3AK'

然后再进行数据加密:

>>> hash = crypt.crypt("helloworld",salt) >>> hash '$6$s8Q3eNP6urKZb3AK$L0O5cqHRU.1f170bV2KrjF3LkLL54So442TqUIsk.wYtCtOSD4Tyt./fj6W6Y.EzrbNm00grA4yPPhXGya2ie1' 三、hashlib (一)hashlib的主要方法和常量 名称描述
md5(…)   利用md5算法加密  
sha1(…)   利用sha1算法加密  
sha224(…)   利用sha224算法加密  
sha256(…)   利用sha256算法加密  
sha384(…)   利用sha384算法加密  
sha512(…)   利用sha512算法加密  
**(二)Hash对象特有的方法

如果你利用hashlib生成了一个Hash对象,那么这个Hash对象会包含如下方法:

名称描述
update(arg)   可以重复利用指定了特殊加密算法的Hash对象,对arg进行加密  
digest(…)   以字符形式返回加密内容  
hexdigest(…)   以16进制形式返回加密内容  
copy(…)   为了达到重复利用Hash对象的目的,而克隆Hash对象  
(三)示例 1、直接使用hashlib方法 >>> hashlib.sha224("Nobody inspects the spammish repetition") <sha224 HASH object @ 0x7f99432c5b28> >>> hashlib.sha224("Nobody inspects the spammish repetition").hexdigest() 'a4337bc45a8fc544c03f52dc550cd6e1e87021bc896588bd79e901e2' 2、直接使用Hash对象中的方法 >>> m = hashlib.md5() >>> m <md5 HASH object @ 0x7f99432c5468> >>> m.update("Nobody inspects") >>> m.digest() '>\xf7)\xcc\xf0\xccV\x07\x9c\xa5F\xd5\x80\x83\xdc\x12' >>> m.update(" the spammish repetition") >>> m.digest() '\xbbd\x9c\x83\xdd\x1e\xa5\xc9\xd9\xde\xc9\xa1\x8d\xf0\xff\xe9' >>> m.hexdigest() 'bb649c83dd1ea5c9d9dec9a18df0ffe9'

本文永久更新链接地址

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/e607984b06be73b5b256730f6d789613.html