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

编程入门 行业动态 更新时间:2024-10-10 05:19:11

密码<a href=https://www.elefans.com/category/jswz/34/1753758.html style=加盐加密存储及其登录验证方式"/>

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

概述

本文介绍一种常用的密码加密存储方式,并附上登录时验证用户密码的方法。代码用 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

更多推荐

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

本文发布于:2024-02-06 05:14:59,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1746579.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:加盐   密码   方式

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!