1.MD5加密的定义
- MD5的全称是Message-Digest Algorithm 5。MD5加密算法是一种单向加密的手段,属于计算机安全领域中的散列加密,使用的是Hash算法。
- MD5加密之后是一个字符串,是一个定长的32位的字符串。MD5先将原来的数据变成一个16个字节的数组,然后将这个长度为16的字节数组用16进制表示,这个16进制的字符串就是加密最后的结果。
2.MD5加密的特点
- MD5加密之后的字符串是定长的,长度是32。
- MD5加密是单向加密,不可逆(从结果无法反推原始数据)。
- MD5抗碰撞性,即两个明文不同的字符串MD5加密之后几乎不可能相同。
3.MD5的应用场景
- 用户密码保护:将数据库密码加密之后存入数据库中,在以后登录的时候,将输入的密码进行MD5加密,然后再讲加密后的字符串和数据库中的进行比较。
- 文件完整性校验:先在发送端计算一次文件的MD5值,然后接收端接收到数据之后,再计算一次MD5值,然后比较两次的MD5值,如果一样,文件就是完整的。
- 云盘秒传:云盘上传时计算MD5,并在自己的数据库中搜索一下 MD5是否存在,存在则使用已有的文件就可以了,从而实现云盘秒传。
- 数字发布:程序发布时,发布其MD5值,下载之后,计算一个MD5值,比较这两个MD5值是否相同,通过这种方式可以知道程序是否被篡改。
4.MD5的代码实现
public class MD5 {
/**
* MD5加密算法的调用
* @param string 明文
* @return 返回加密后的密文
*/
public static String md5Encrypt(String string) throws NoSuchAlgorithmException {
byte[] bytes = string.getBytes(StandardCharsets.UTF_8);
MessageDigest digest = MessageDigest.getInstance("md5");
byte[] result = digest.digest(bytes);
//对于加密后的结果进行输出:将字节数组转为16进制的字符串
StringBuffer sb = new StringBuffer();
for (byte b : result) {
int num = b & 0xff;//加盐,转类型的时候保证补码相同
String str = Integer.toHexString(num);
if(str.length() == 1){
sb.append("0");
}
sb.append(str);
}
return sb.toString();
}
public static void main(String[] args) throws NoSuchAlgorithmException {
String text = "123456";
String md5Encrypt = md5Encrypt(text);
//123456使用MD5加密之后的值是e10adc3949ba59abbe56e057f20f883e
System.out.println("e10adc3949ba59abbe56e057f20f883e".equals(md5Encrypt));
System.out.println(text + "MD5加密之后的值是:" + md5Encrypt);
}
}
参考:https://blog.csdn.net/m0_46582525/article/details/123757932