hashlib
hashlib主要提供字符加密功能,将md5和sha模块整合到了一起,支持md5,sha1, sha224, sha256, sha384, sha512等算法
hashlib模块
#哈希算法也叫摘要算法,相同的数据始终得到相同的输出,不同的数据得到不同的输出。
#(1)哈希将不可变的任意长度的数据,变成具有固定长度的唯一值
#(2)字典的键值对映射关系是通过哈希计算的,哈希存储的数据是散列(无序)
# 应用场景:在需要效验功能时使用
用户密码的 => 加密,解密
相关效验的 => 加密,解密
hashlib中的MD5算法
# 第一步是引包 import hashlib # 创建一个md5算法的对象 hs = hashlib.md5() # print(hs) # update中的 参数必须是二进制字节流 hs.update("123".encode()) ## hexdigest 返回32位十六进制的字符串(固定长度) ## 用一个hsvar来接收经过哈希算法返回的值 hsvar = hs.hexdigest()
#加盐 (就是在简单的算法中进行加入混肴参数)
语法格式如下:
#首先在实例化hashlib中的MD5对象的时候,加入混淆参数key,以此达到更加复杂的加密) #加入的key参数一定也要是字节流 hs2 = hashlib.md5("abcd".encode()) hs2.update("123123".encode()) hs2var = hs2.hexdigest()
加盐后的好处就是,增加了加密的安全性,使其不那么容易被破解
但因为hash算法是被公开的算法,其安全性不那么好,一些简单的加密 值很容易被逆向破解出来,说逆向破解也不那么准确,
一般来说,破解此类算法只能使用穷举法, 可以将 跑出来的值存入到一个大的数据库中,哈希算法得出的值有唯一性,所以可以反向查询已有的hash值来得到原始数据,当然这种网站也有, 我百度上看到的一个网站,你们可以进去看一看,一般的哈希值都能查询到原数据,只要他们数据库中有的话.
所以说最好的方法就是我们要加盐,去加入复杂混肴参数,这样的话大大提高了数据加密的安全性
链接: https://www.cmd5.com/ md5解密(本链接只作为学习使用,勿将其使用到任何非法用途)
在开发编程中,常用到hash算法的方面应该有用户的注册登录
下面有我写的一个实例,供大家参考(为了方便大家的阅读,这个注册登录功能我没有完善,比如说用正则去卡用户名和密码的格式等等,)
import hashlib #定义一个加密函数,将传入的参数转换成32位的哈希值并返回 def md5(pwd): md5_password = hashlib.md5("abd".encode()) md5_password.update(pwd.encode()) return md5_password.hexdigest() #定义一个登录函数,将传入的账号密码与本地密码文件进行匹配,如果匹配到返回True def login(user,pwd): with open("database","r",encoding="utf-8") as fp: for line in fp : u,p = line.strip().split("|") if u == user and p == md5(pwd): return True #定义一个注册的函数,将用户传入的账号密码写入到本地的密码文件中 def register(user,pwd): with open("database","w",encoding="utf-8") as fp: temp = user+ "|" + md5(pwd) fp.write(temp) #index菜单,给用户的交互 choice = input("1表示登录, 2表示注册:").strip() if choice == "2": user = input("用户名:") pwd = input("密码:") register(user,pwd) elif choice == "1": user = input("用户名:") pwd = input("密码:") r = login(user,pwd) if r == True: print("登录成功") else: print("登录失败") else: print("账号不存在")
hashlib中的sha算法
"https://twitter.com/matthew_d_green">https://twitter.com/matthew_d_green)在这一领域也有不错的成就.
import hashlib #实例化sha1对象 hs3 = hashlib.sha1() #去将要去加密的数据通过一个方法放入对象中 hs3.update('123123'.encode()) #调用对象中的方法,计算并输出加密后的40位的哈希值 hsvar = hs3.hexdigest()
sha算法常用的有 sha1 sha512等,语法一样,只不过输出的哈希值的长度不一样,所以就不一一列举了
总结
以上所述是小编给大家介绍的python中的hashlib模块的使用,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。