一、介绍
            
          
          
        
如果在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就应该使用下面的命令:
            
>>>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")
            
              
>>> hashlib.sha224("Nobody inspects the spammish repetition").hexdigest()
'a4337bc45a8fc544c03f52dc550cd6e1e87021bc896588bd79e901e2'
             
          
        
          2、直接使用Hash对象中的方法
          
        
            
>>> m = hashlib.md5()
>>> m
            
              
>>> 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'
             
          
        我是如何 Python 一句话校验软件哈希值的
MD5
            
python -c "import hashlib,sys;print hashlib.md5(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe
          
        校验 下载软件是否被“中间人动过手脚”
例如:校验shadowsocks
SHA-1
            
python -c "import hashlib,sys;print hashlib.sha1(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe
          
        SHA-256
            
python -c "import hashlib,sys;print hashlib.sha256(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe
          
        SHA-512
            
python -c "import hashlib,sys;print hashlib.sha512(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe
          
        总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。


 
					 
					