基于SpringBoot框架的MD5加密
基于SpringBoot实现MD5的二次加密
·
一般来说,为了数据的安全性,需要对密码进行两次MD5加密,第一次是在前端输入完明文密码后加密,第二次是在后端接收到前端经过MD5加密的密码后,存到数据库前进行MD5加密。
具体流程参考如下:
1. 导入相关依赖
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.6</version>
</dependency>
2.创建MD5工具类
@Component
public class MD5Utils {
public static String md5(String src){
return DigestUtils.md5Hex(src);
}
private static final String salt = "1a2b3c4d";
//第一次加密
public static String inputPassToFormPass(String inputPass){
//md5加密密码前,先对密码进行处理,按以下salt的规则处理密码
String str = "" + salt.charAt(0) + salt.charAt(2) + inputPass + salt.charAt(5) + salt.charAt(4);
return md5(str);
}
//第二次加密
public static String formPassToDBPass(String formPass, String salt){
String str = "" + salt.charAt(0) + salt.charAt(2) + formPass + salt.charAt(5) + salt.charAt(4);
return md5(str);
}
//实际调用的方法,将第一次加密和第二次加密合并,结果应该一致
public static String inputPassToDBPass(String inputPass, String salt){
String formPass = inputPassToFormPass(inputPass);
String dbPass = formPassToDBPass(formPass, salt);
return dbPass;
}
public static void main(String[] args) {
//d3b1294a61a07da9b49b6e22b2cbd7f9
System.out.println(inputPassToFormPass("123456"));
//b7797cce01b4b131b433b6acf4add449
System.out.println(formPassToDBPass("d3b1294a61a07da9b49b6e22b2cbd7f9","1a2b3c4d"));
//b7797cce01b4b131b433b6acf4add449
System.out.println(inputPassToDBPass("123456","1a2b3c4d"));
}
}
PS:MD5的库文件应该是org.apache.commons.codec.digest.DigestUtils。
更多推荐
已为社区贡献1条内容
所有评论(0)