SpringBoot框架的MD5加密方式

2023-03-22 17:03:09 框架 方式 加密

SpringBoot框架MD5加密

一般来说,为了数据的安全性,需要对密码进行两次MD5加密,第一次是在前端输入完明文密码后加密,第二次是在后端接收到前端经过MD5加密的密码后,存到数据库前进行MD5加密。       

具体流程参考如下:       

导入相关依赖

        <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>        

创建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"));
 
    }
}

SpringBoot自带MD5加密

导入包

import org.springframework.util.DigestUtils;

对密码进行 md5 加密

String md5PassWord = DigestUtils.md5DigestAsHex(user.getPassword().getBytes());

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

相关文章