一、介绍
如果在Python中需要对用户输入的密码或者其他内容进行加密,首选的方法是生成hash值。 在Python中可以利用二个模块来进行: - crypt - hashlib 二、crypt
(一)crypt的主要方法和常量
名称 描述
md5(…) 利用md5算法加密
sha1(…) 利用sha1算法加密
sha224(…) 利用sha224算法加密
sha256(…) 利用sha256算法加密
sha384(…) 利用sha384算法加密
sha512(…) 利用sha512算法加密
(二)使用说明与示例
使用crypt.crypt(…)进行hash加密的时候,需要提供二个参数: - 加密内容 - salt 如果不特别指定salt,系统就会调用crypt.mksalt(…)生成一个salt 如果想要以特定的加密算法生成salt就应该使用下面的命令: [size=1em][size=1em]1
[size=1em]2
[size=1em]3
| [size=1em][size=1em]>>>salt = crypt.mksalt(crypt.METHOD_SHA512)
[size=1em]>>> salt
[size=1em]'$6$s8Q3eNP6urKZb3AK'
|
然后再进行数据加密: [size=1em][size=1em]1
[size=1em]2
[size=1em]3
| [size=1em][size=1em]>>> hash = crypt.crypt("helloworld",salt)
[size=1em]>>> hash
[size=1em]'$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方法
[size=1em][size=1em]1
[size=1em]2
[size=1em]3
[size=1em]4
| [size=1em][size=1em]>>> hashlib.sha224("Nobody inspects the spammish repetition")
[size=1em]<sha224 HASH object @ 0x7f99432c5b28>
[size=1em]>>> hashlib.sha224("Nobody inspects the spammish repetition").hexdigest()
[size=1em]'a4337bc45a8fc544c03f52dc550cd6e1e87021bc896588bd79e901e2'
|
2、直接使用Hash对象中的方法
[size=1em][size=1em]1
[size=1em]2
[size=1em]3
[size=1em]4
[size=1em]5
[size=1em]6
[size=1em]7
[size=1em]8
[size=1em]9
[size=1em]10
[size=1em]11
| [size=1em][size=1em]>>> m = hashlib.md5()
[size=1em]>>> m
[size=1em]<md5 HASH object @ 0x7f99432c5468>
[size=1em]>>> m.update("Nobody inspects")
[size=1em]>>> m.digest()
[size=1em]'>\xf7)\xcc\xf0\xccV\x07\x9c\xa5F\xd5\x80\x83\xdc\x12'
[size=1em]>>> m.update(" the spammish repetition")
[size=1em]>>> m.digest()
[size=1em]'\xbbd\x9c\x83\xdd\x1e\xa5\xc9\xd9\xde\xc9\xa1\x8d\xf0\xff\xe9'
[size=1em]>>> m.hexdigest()
[size=1em]'bb649c83dd1ea5c9d9dec9a18df0ffe9'
|
我是如何 Python 一句话校验软件哈希值的 MD5 [size=1em][size=1em]1
| [size=1em][size=1em]python -c "import hashlib,sys;print hashlib.md5(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe
|
校验 下载软件是否被“中间人动过手脚” 例如:校验shadowsocks SHA-1 [size=1em][size=1em]1
| [size=1em][size=1em]python -c "import hashlib,sys;print hashlib.sha1(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe
|
SHA-256 [size=1em][size=1em]1
| [size=1em][size=1em]python -c "import hashlib,sys;print hashlib.sha256(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe
|
SHA-512 [size=1em][size=1em]1
| [size=1em][size=1em]python -c "import hashlib,sys;print hashlib.sha512(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe
|
总结 以上就是这篇文章的全部内容了
|