Java实现登录密码不可逆加密(MD5+随机盐值)

阅读: 评论:0

Java实现登录密码不可逆加密(MD5+随机盐值)

Java实现登录密码不可逆加密(MD5+随机盐值)

工具类使用背景

当前是信息安全时代,对于用户登录密码进行不可逆的MD5加密是必不可少的,并增加一定的字节随机盐值防止暴力破解,保证同一密码多次加密结果不一样。

第三方依赖

    <dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.0.7</version></dependency>

极致核心代码

import util.ArrayUtil;
import util.HexUtil;
import pto.digest.MD5;
import java.nio.charset.Charset;
import java.security.SecureRandom;
import java.util.Arrays;/*** @author huangrusheng* @version 1.0* @date 2021/5/21 16:40*/
public final class PasswordUtil {private PasswordUtil(){}/*** 随机盐值字节数*/private static final int SALT_BYTE_LENGTH = 20;private static final Charset CHARSET = Charset.forName("UTF-8");public static String encrypt(String password){SecureRandom secureRandom = new SecureRandom();byte salt[] = new byte[SALT_BYTE_LENGTH];Bytes(salt);MD5 md5 = new MD5(salt);byte[] digest = md5.digest(password,CHARSET);//填充前20个字节为盐值,校验密码时候需要取出byte[] pwd = ArrayUtil.addAll(salt,digest);deHexStr(pwd);}public static boolean valid(String password,String encryptedPassword){byte[] encryptedPwd = HexUtil.decodeHex(encryptedPassword);//取出前20个字节盐值byte[] salt =  ArrayUtil.sub(encryptedPwd,0,SALT_BYTE_LENGTH);//20字节后为真正MD5后密码byte[] pwd = ArrayUtil.sub(encryptedPwd,SALT_BYTE_LENGTH,encryptedPwd.length);MD5 md5 = new MD5(salt);byte[] digest = md5.digest(password,CHARSET);return Arrays.equals(digest,pwd);} 
}

单元测试用列

slf4j.Slf4j;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;/*** @author huangrusheng* @version 1.0* @date 2021/5/21 17:04*/
@Slf4j
@RunWith(JUnit4.class)
public class PasswordTest {@Testpublic void testPassword(){String password = "hrs@qt16c";String encryptedPassword = pt(password);log.info("生成不可逆16进制加密密码:{}",encryptedPassword);log.info("校验登录密码是否正常:{}",PasswordUtil.valid(password,encryptedPassword));log.info("原始密码追加内容,在校验登录密码是否正常:{}",PasswordUtil.valid(password+"663",encryptedPassword));}}

本文发布于:2024-02-01 06:23:18,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170673980034523.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:密码   Java
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23