MD5(Message-Digest Algorithm 5 信息-摘要算法
MD5不属于对称加密也不属于非对称加密,是一种摘要算法
相同内容经过MD5加密后是一样的
MD5属于单向加密,不能解码,只能暴力破解
暴力破解原理是提前存储了常见明文对应的密文
MD5暴力破解地址 https://www.cmd5.com/
使用场景
(1) 存储密码等敏感信息时,若不加密可能会出现安全问题。如:系统登录密码,若密码采用明文存储,可能会被泄漏。使用MD5加密后即使数据泄露,也不会被轻易的破解。一般使用登录密码加盐(动态的若使用用户id)后再MD5后再存储在数据库
(2) 文件内容是否变化。文件变化前后的MD5值不一样,比较MD5值是否一样就知道文件是否发生了改变,如配置中心/Maven/git等就是这样用的。不能检测文件名,文件名发生变化MD5值是不变的
代码
public class MD5Util {
// 加盐
private static final String SALT = "salt";
public static String encode(String password) {
password = password + SALT;
MessageDigest md5 = null;
try {
md5 = MessageDigest.getInstance("MD5");
} catch (Exception e) {
throw new RuntimeException(e);
}
char[] charArray = password.toCharArray();
byte[] byteArray = new byte[charArray.length];
for (int i = 0; i < charArray.length; i++)
byteArray[i] = (byte) charArray[i];
byte[] md5Bytes = md5.digest(byteArray);
StringBuffer hexValue = new StringBuffer();
for (int i = 0; i < md5Bytes.length; i++) {
int val = ((int) md5Bytes[i]) & 0xff;
if (val < 16) {
hexValue.append("0");
}
hexValue.append(Integer.toHexString(val));
}
return hexValue.toString();
}
}
public static void main(String[] args) {
String encode = MD5Util.encode("123");
System.out.println(encode);
}