python md5加密和加盐_python的md5摘要(加密)与加盐

本文介绍了Python中使用hashlib库进行MD5加密的过程,强调了MD5摘要的不可逆性,并展示了如何在加密过程中加入盐值,以增强密码的安全性。通过示例代码,解释了加盐MD5在用户验证时的重要性。
摘要由CSDN通过智能技术生成

python的hashlib库的md5摘要是不可反解的,非常安全

摘要是单项不可逆的

加密是可以解密的,是双向的

haxdigest  hax是16进制,digest是摘要

#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('登录失败')

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值