python基础2-hashlib模块

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

补充:

import hashlib
m = hashlib.md5()
m.update(b'hello')
print(m.digest())
m.update(b'world')
print(m.digest())
print(m.hexdigest())
m1 = hashlib.md5()
m1.update(b'helloworld')
print(m1.digest())
print(m1.hexdigest())

#返回
'''
b']A@*\xbcK*v\xb9q\x9d\x91\x10\x17\xc5\x92'
b'\xfc^\x03\x8d8\xa5p2\x08TA\xe7\xfep\x10\xb0'
fc5e038d38a57032085441e7fe7010b0
b'\xfc^\x03\x8d8\xa5p2\x08TA\xe7\xfep\x10\xb0'
fc5e038d38a57032085441e7fe7010b0
'''

注:发现,m的hello的md5后,再m的world的md5后 ,与m1的helloworld后值一致

import hashlib
 
m = hashlib.md5()
m.update(b"Hello")
m.update(b"It's me")
print(m.digest())
m.update(b"It's been a long time since last time we ...")
 
print(m.digest()) #2进制格式hash
print(len(m.hexdigest())) #16进制格式hash
'''
def digest(self, *args, **kwargs): # real signature unknown
    """ Return the digest value as a string of binary data. """
    pass
 
def hexdigest(self, *args, **kwargs): # real signature unknown
    """ Return the digest value as a string of hexadecimal digits. """
    pass
 
'''
import hashlib
 
# ######## 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())
View Code
import hashlib

hash = hashlib.sha256()
hash.update("罗利宇".encode(encoding='utf-8'))
print(hash.hexdigest())
print(hash.digest())

#返回
#a7c010539eb337711e91f4d2403e2868a31ea5672df8e9815e7ec219b03d4f21
#b'\xa7\xc0\x10S\x9e\xb37q\x1e\x91\xf4\xd2@>(h\xa3\x1e\xa5g-\xf8\xe9\x81^~\xc2\x19\xb0=O!'

  

 

还不够吊?python 还有一个 hmac 模块,它内部对我们创建 key 和 内容 再进行处理然后再加密

散列消息鉴别码,简称HMAC,是一种基于消息鉴别码MAC(Message Authentication Code)的鉴别机制。使用HMAC时,消息通讯的双方,通过验证消息中加入的鉴别密钥K来鉴别消息的真伪;

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

import hmac
h = hmac.new("天王盖地虎".encode(encoding='utf-8'),"宝塔镇河妖".encode(encoding='utf-8'))
print(h.hexdigest())
#返回 5f90dcd2211cd11601ce05195e3c5232

  

更多关于md5,sha1,sha256等介绍的文章看这里 https://www.tbs-certificates.co.uk/FAQ/en/sha256.html 

posted @ 2017-09-13 17:05  larlly  阅读(606)  评论(0)    收藏  举报