1 MD5加密介绍
- MD5是一个加密的算法,可以对明文字符串进行加密,得到一个密文。
- MD5原文和密文是一对一的键值对。
例如:原文:123 密文:202cb962ac59075b964b07152d234b70
不管执行多少次,加密算法是固定的,得到的密文永远不变
相对来说就不安全,容易被破解
- 公司中使用MD5进行加密
例如:原文密码是123,把首尾交换,再加上用户名进行加密
例如:321meimei 进行加密e5212215b8cbf493e04f4290cf7cecc8
这样做相对来说会安全
package com.itheima.travel.util;
import java.security.MessageDigest;
/**
* 写一个MD5算法,运行结果与MySQL的md5()函数相同
* 将明文密码转成MD5密码
* 123456->e10adc3949ba59abbe56e057f20f883e
*/
public final class Md5Util {
private Md5Util(){
}
/**
* 将明文密码转成MD5密码
*/
public static String encodeByMd5(String password) throws Exception{
//Java中MessageDigest类封装了MD5和SHA算法,今天我们只要MD5算法
MessageDigest md5 = MessageDigest.getInstance("MD5");
//调用MD5算法,即返回16个byte类型的值
byte[] byteArray = md5.digest(password.getBytes());
//注意:MessageDigest只能将String转成byte[],接下来的事情,由我们程序员来完成
return byteArrayToHexString(byteArray);
}
/**
* 将byte[]转在16进制字符串
*/
private static String byteArrayToHexString(byte[] byteArray) {
StringBuffer sb = new StringBuffer();
//遍历
for(byte b : byteArray){
//16次
//取出每一个byte类型,进行转换
String hex = byteToHexString(b);
//将转换后的值放入StringBuffer中
sb.append(hex);
}
return sb.to