用户模块关于弱密码md5加密

在用户登录时,应避免直接使用明文密码对比,推荐使用带有加密盐的MD5处理,以增强安全性。即使数据库泄露,也不能直接解密密码。同时,登录失败的错误信息应统称为用户名或密码错误,避免暴露用户注册信息。对于JWTToken,应结合用户IP进行MD5加密,确保令牌安全,IP变化时需重新登录。
摘要由CSDN通过智能技术生成

在做用户登录的时候,获取到用户username和password,此时我们有两种比较方法:

-- 第一种
select * from user where username = ? and password = ?

-- 第二种
select * from user where username = ?

我们应该使用哪一种呢?

答案是第二种。因为第一种表示数据库存储的就是md5(用户密码),如果用户的密码是弱密码,那么数据库一旦泄露,那么使用md5解密就有可能能获取到用户的密码,不安全。所以解决办法是在用户表中再加入一个字段salt(加密盐,可以是一串uuid,每个用户唯一),用户在注册或者修改密码的时候,把salt加到用户输入的密码后面,然后再使用md5加密存储到数据库中。这种复杂的密码,是无法进行md5解密的。

基于以上分析,我们已经清楚,在比对用户密码的时候要先拿到该用户的salt,拼接在用户密码的后面,再使用md5加密,然后与数据库中的密码进行比对。所以我们只能使用第二种sql才能达到这种效果。

还有一个注意的点是,当username不存在时应该返回什么错误信息呢?最好不要回复“用户名不存在”,因为这样的话,其他人就知道哪些用户名被注册过,所以最好还是回复“用户名或密码错误” 。       

补充一点:

用户登录后会生成jwt token,为了防止jwt token泄露,提供一种解决方案:

  • 每次生成令牌的时候,把用户的IP作为令牌的一部分进行MD5加密,并将密文存入到令牌中
  • 用户每次访问API接口的时候,都先获取客户端IP,再将IP进行MD5加密,并和令牌中的IP密文比对
  • 如果密文一致,则证明IP没有发生变化,如果密文不一致,则证明IP发生变化,提示重新登录

散的知识点

token校验的密钥能不存放其他模块就不存放其他模块

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值