hashlib模块
######### md5 ######## hash = hashlib.md5() hash.update(bytes(‘admin‘, encoding=‘utf-8‘)) # 或hash.update("admin".encode("utf-8")) print(hash.hexdigest()) # 16进制 print(hash.digest()) ######## sha1 ######## hash = hashlib.sha1() hash.update(bytes(‘admin‘, encoding=‘utf-8‘)) print(hash.hexdigest()) ######### sha256 ######## hash = hashlib.sha256() hash.update(bytes(‘admin‘, encoding=‘utf-8‘)) print(hash.hexdigest()) ######### sha384 ######## hash = hashlib.sha384() hash.update(bytes(‘admin‘, encoding=‘utf-8‘)) print(hash.hexdigest()) ######### sha512 ######## hash = hashlib.sha512() hash.update(bytes(‘admin‘, encoding=‘utf-8‘)) print(hash.hexdigest())
以上加密算法虽然依然非常厉害,但时候存在缺陷,即:通过撞库可以反解。所以,有必要对加密算法中添加自定义key再来做加密。
######### md5 ######## hash = hashlib.md5(bytes(‘898oaFs09f‘,encoding="utf-8")) hash.update(bytes(‘admin‘,encoding="utf-8")) print(hash.hexdigest())
python内置还有另一个 hmac 模块,它内部对我们创建 key 和 内容 进行进一步的处理然后再加密
import hmac h = hmac.new(bytes(‘898oaFs09f‘,encoding="utf-8")) h.update(bytes(‘admin‘,encoding="utf-8")) print(h.hexdigest())
random模块
random.random() # 生成0~1之间的数 random.randint(1,8) # 生成1~8之间的整数(包括8) random.choice(‘hello‘) # 生成随机字母
序列化
Python中用于序列化的两个模块
- json 用于【字符串】和 【python基本数据类型】 间进行转换
- pickle 用于【python特有的类型】 和 【python基本数据类型】间进行转换
Json模块提供了四个功能:dumps、dump、loads、load
pickle模块提供了四个功能:dumps、dump、loads、load
import json data = {‘k1‘:‘v1‘,‘k2‘:‘v2‘} json.dumps(data) # 将数据转换成pickle字符串(所有程序语言都认识,只能转换字典,列表等基本类型) >> ‘{"k1": "v1", "k2": "v2"}‘ import pickle data = {‘k1‘:‘v1‘,‘k2‘:‘v2‘} pickle.dumps(data) # 将数据转换成pickle字符串(只有Python语言认识,可以转换python中的函数、类...) >> b‘\x80\x03}q\x00(X\x02\x00\x00\x00k1q\x01X\x02\x00\x00\x00v1q\x02X\x02\x00\x00\x00k2q\x03X\x02\x00\x00\x00v2q\x04u.‘
将序列化后的字符串保存到文件中
data = {‘k1‘:‘v1‘} import pickle with open("abc123.txt",‘wb‘) as f: pickle.load(data,f) # 将data中的数据保存到文件中 import json with open("abc123.txt",‘w‘) as f: json.dump(data,f) # 将data中的数据保存到文件中