MD5算法由于其本身的不可逆性,在行业内用的很普遍。一般为了保证用户的密码安全,在service层会对用户的密码进行MD5算法加密,防止数据库数据丢失造成用户的损失。在此做一个简单的小结。
1.MD5算法需要用到JDK中的MessageDigest类
2.对加密后的数据再次进行处理
import java.security.MessageDigest;
/*
* 负责给字符串数据进行加密
*/
public class MD5Utils {
public static String getPWD( String strs ){
/*
* 加密需要使用JDK中提供的类
*/
StringBuffer sb = new StringBuffer();
try{
MessageDigest digest = MessageDigest.getInstance("MD5");
//该方法将字节数组进行加密,返回一个字节数组
byte[] bs = digest.digest(strs.getBytes());
/*
* 把取出的数据转成十六进制数
*/
for (byte b : bs) {
int x = b & 255;//取出数据的后8位
String s = Integer.toHexString(x);
//如果处理后的数据只有4位再加一位,保证处理后数据长度固定
if( x > 0 && x < 16 ){
sb.append("0");//不够前一位补0
sb.append(s);
}else{
sb.append(s);
}
}
}catch( Exception e){
System.out.println("加密失败");
}
return sb.toString();
}
}