python的md5摘要(加密)与加盐
python的hashlib库的md5摘要是不可反解的,非常安全
摘要是单项不可逆的
加密是可以解密的,是双向的
haxdigest hax是16进制,digest是摘要
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | #md5加密是不可反解的 import hashlib #实例化对象 obj = hashlib.md5() #先创建一个md5的对象 #写入要加密的字节 obj.update( "admin" .encode( "utf-8" )) #对谁加密就把谁写道前面,python3中必须是字节,所以必须用.encode() #获取密文 secret = obj.hexdigest() print (secret) ############################################################## import hashlib obj = hashlib.md5(b '12334' ) #实例化md5的时候可以给传个参数,这叫加盐 obj.update( "admin" .encode( "utf-8" )) #是再加密的时候传入自己的一块字节, secret = obj.hexdigest() print (secret) ############################################################## #因为用户密码已经被加密过了,而且是加盐的,所以再用户验证的时候用字符串或者直接的加密的的字节都不能正确判断,只能用加盐的字节所判断 import hashlib SALT = b '2erer3asdfwerxdf34sdfsdfs90' def md5(pwd): # 实例化对象 obj = hashlib.md5(SALT) # 写入要加密的字节 obj.update(pwd.encode( 'utf-8' )) # 获取密文 return obj.hexdigest() user = input ( "请输入用户名:" ) pwd = input ( "请输入密码:" ) if user = = 'oldboy' and md5(pwd) = = 'c5395258d82599e5f1bec3be1e4dea4a' : print ( '登录成功' ) else : print ( '登录失败' ) |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律