密码加盐加密存储及其登录验证方式

概述

本文介绍一种常用的密码加密存储方式,并附上登录时验证用户密码的方法。代码用 Java 来实现,结尾附带有 github 的源码链接。

创建账号

用户注册账号,填写好密码后传递到后端。密码的形式一般是经过前端 md5 加密过的。

账号实体类

public class Account {

    /**
     * 其他账号的字段省略
     */

    private String salt;

    private String hashedCredential;

	// 省略getter setter方法
}

密码处理逻辑

/**
 * 创建账号
 * @param principle 用户账号
 * @param frontendPassword 用户密码,用户在前端输入的密码以 md5 的形式传到后端
 */
public void createAccount(String principle, String frontendPassword) {

    Account account = md5WithSalt(frontendPassword);

    // 保存账号,模拟数据库保存
    DB_ACCOUNTS.put(principle, account);
}

// ~ private
private Account md5WithSalt(String frontendPassword) {

    Account account = new Account();
    
    // 随机字符串做盐
    account.setSalt(UUID.randomUUID().toString());
    // 盐和密码结合取hash值
    account.setHashedCredential(SecurityUtil.md5Hex(account.getSalt() + frontendPassword));

    return account;
}

登录校验

根据账号来获取它的盐并且和登录时输入的密码求hash,此 hash 值和数据库存取的 hash 值相等则密码校验通过。

/**
 * 登录逻辑
 * @param principle 用户账号
 * @param frontendPassword 用户密码,用户在前端输入的密码以 md5 的形式传到后端
 * @return true-登录成功,false-登录失败
 */
public Boolean login(String principle, String frontendPassword) {

    Account account = DB_ACCOUNTS.get(principle);
    if (account == null) {
        return false;
    }

    return account.getHashedCredential()
            .equals(SecurityUtil.md5Hex(account.getSalt() + frontendPassword));
}

示例源码

LoginDemo.java

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值