用于加密相关的操作,3.x里代替了md5(不可反解)模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法

import           hashlib         


                    


          m           =           hashlib.md5()         


          m.update(b          "Hello"          )         


          m.update(b          "It's me"          )         


          print          (m.digest())         


          m.update(          "中文支持格式".encode(encoding="utf-8")          )         


                    


          print          (m.digest())           #2进制格式hash         


          print          (          len          (m.hexdigest()))           #16进制格式hash         





          # ######## md5 ########         


                    


          hash           =           hashlib.md5()         


          hash          .update(          'admin'          )         


          print          (          hash          .hexdigest())         


                    


          # ######## sha1 ########         


                    


          hash           =           hashlib.sha1()         


          hash          .update(          'admin'          )         


          print          (          hash          .hexdigest())         


                    


          # ######## sha256 ########         


                    


          hash           =           hashlib.sha256()         


          hash          .update(          'admin'          )         


          print          (          hash          .hexdigest())         


                    


                    


          # ######## sha384 ########         


                    


          hash           =           hashlib.sha384()         


          hash          .update(          'admin'          )         


          print          (          hash          .hexdigest())         


                    


          # ######## sha512 ########         


                    


          hash           =           hashlib.sha512()         


          hash          .update(          'admin'          )         


          print          (          hash          .hexdigest())


python 还有一个 hmac 模块,它内部对我们创建 key和value再进行处理然后再加密,散列消息鉴别码,简称HMAC,是一种基于消息鉴别码MAC(Message Authentication Code)的鉴别机制。使用HMAC时,消息通讯的双方,通过验证消息中加入的鉴别密钥K来鉴别消息的真伪;

一般用于网络通信中消息加密,前提是双方先要约定好key,就像接头暗号一样,然后消息发送把用key把消息加密,接收方用key + 消息明文再加密,拿加密后的值 跟 发送者的相对比是否相等,这样就能验证消息的真实性,及发送者的合法性了。

import           hmac           


          h1           =           hmac.new(b          '12345'          , b          'your name is Julia'          )         


          h2 = hmac.new(b'12345', '我是中文'.encode(encoding="utf-8"))
         


          print           h1.hexdigest()