可以直接作为一个工具类,传入一个字符串,则返回一个加密后的字符串
public class MD5Util {
public static String md5(String pas) {
//pas为空时返回值为:becf72503940cf7ff0df9c224118e8f6
//加盐处理
String pass = pas + "mobilesafe";
try {
//1指定加密算法类型
MessageDigest digest = MessageDigest.getInstance("MD5");
//2将加密的字符串中专成byte类型数组,然后进行hash过程
byte[] bs = digest.digest(pass.getBytes());
//3进行循环遍历bs,然后让其生成32位字符串,固定写法
//4拼接成字符串过程
StringBuffer stringBuffer=new StringBuffer();
for (byte b : bs) {
int i = b & 0xff;
//byte类型的数字要&0xff再赋值给int类型,
//其本质原因就是想保持二进制补码的一致性。
//int 类型的i需要转换为16进制字符
String hexString = Integer.toHexString(i);
if(hexString.length()<2){
hexString+="0";
}
stringBuffer.append(hexString);
}
//测试
System.out.println("加密结果"+stringBuffer.toString());
return stringBuffer.toString();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return "";
}
}