码迷,mamicode.com
首页 > 编程语言 > 详细

python的hashlib模块

时间:2017-02-28 19:37:51      阅读:178      评论:0      收藏:0      [点我收藏+]

标签:nat   pre   16进制   hash   iges   通信   网络通信   python   网络   

hashlib模块  

用于加密相关的操作,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(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

 

‘‘‘

# ######## 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 和 内容 再进行处理然后再加密

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

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

import hmac

h = hmac.new(bhello,bcabel)
print(h.hexdigest())

 

python的hashlib模块

标签:nat   pre   16进制   hash   iges   通信   网络通信   python   网络   

原文地址:http://www.cnblogs.com/caibao666/p/6480122.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!