Java MD5加密
常见三种MD5加密方式
- 使用DigestUtils类的md5Hex方法
- 使用spring核心包的DigestUtils进行加密
- Java核心包实现MD5加密
使用DigestUtils类的md5Hex方法(推荐)
需要导入jar包:commons-codec.jar
maven依赖:
<dependency>
<groupId>org.apache.directory.studio</groupId>
<artifactId>org.apache.commons.codec</artifactId>
<version>1.8</version>
</dependency>
gradel依赖:
implementation 'org.apache.directory.studio:org.apache.commons.codec:1.8'
加密代码:
public static String encryptMD5ByDigestUtils(String str) {
return DigestUtils.md5Hex(str);
}
使用spring核心包的DigestUtils进行加密
需要jar包:spring-core-5.3.23.jar,一般不单独使用这一个包。引入spring框架都带有核心包。
maven依赖:
<!--
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.3.23</version>
</dependency>
gradel依赖:
implementation group: 'org.springframework', name: 'spring-core', version: '5.3.23'
加密代码:
public static String encryptMD5BySpringCore(String str) {
String md5 = " ";
try {
md5 = org.springframework.util.DigestUtils.md5DigestAsHex(str.getBytes("utf-8"));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return md5;
}
Java核心包实现MD5加密
Java核心包rt.jar
public static String encryptMd5ByJava(String input) {
try {
MessageDigest md = MessageDigest.getInstance("MD5");
byte[] digest = md.digest(input.getBytes());
StringBuilder sb = new StringBuilder();
for (byte b : digest) {
sb.append(String.format("%02x", b));
}
return sb.toString();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
return null;
}
}
MD5(Message-Digest Algorithm 5)加密算法的原理主要包括以下几个步骤(了解):
- 填充:对输入的消息进行填充,使其长度对 512 取模后余数为 448。填充的内容由一个 1 和后续若干个 0 组成。
- 附加长度:在填充后的消息后附加一个 64 位的表示原始消息长度(以位为单位)的值。
- 初始化缓冲区:定义四个 32 位的寄存器(A、B、C、D),并进行初始化。
- 迭代压缩:以 512 位的分组为单位对消息进行处理。通过一系列复杂的逻辑函数运算,不断更新 A、B、C、D 的值。
- 输出结果:经过若干轮迭代后,将 A、B、C、D 组合起来得到 128 位的消息摘要,即 MD5 值。
MD5 算法具有以下特点:
不可逆性:很难通过加密后的结果反推出原始消息。
固定长度输出:始终输出 128 位的摘要。