hashlib 模块,实现了支持多种不同哈希算法的接口,不同 hash 算法的构造函数就是算法名,返回的哈希对象都具有相同接口。哈希算法不是加密算法,所以下面提到的加密不是真的加密,因为真的加密需要能够反推到原始数据
1、模块对象
1.1 各种不同算法 hash 对象
1.1.1 初始化构建类:算法名([data]),例如 md5()、sha1()
参数设置:
data:待加密的数据
1.1.2 实例方法
update(arg):用 arg 更新加密数据,是追加而不是替换
digest():返回加密后二进制结果字符串,大小为 digest_size 字节
hexdigest():返回加密后十六进制结果字符串,长度是 digest 的两倍
copy():复制一个 hash 对象
1.1.3 实例属性
digest_size:哈希结果的字节大小
block_size:哈希算法内部块的字节大小
2、模块常数
hashlib.algorithms:元组形式返回模块支持的哈希算法名
hashlib.algorithms_guaranteed:以 set 形式返回在所有平台上都支持的哈希算法名
hashlib.algorithms_available:以 set 形式返回在当前 python 编译器上都支持的哈希算法名
3、模块方法
hashlib.pbkdf2_hmac(name, password, salt, rounds, dklen=None):更安全的加密方式,name 是哈希算法名,password 是字节型待加密数据,salt 是字节型干扰数据,rounds 是循环次数根据算法和机器决定一般100000,dklen 是结果密钥长度,为 none 就根据哈希算法的值确定
hashlib.new(name[, data]):创建哈希算法对象(非首选), name 是算法名, data 是待加密数据