算法步骤:
1. 将输入的密码字符串转换为字节码,用每个byte去和11111111做与运算并且得到的是int类型的值:
byte & 11111111;
2. 把int 类型转成 16进制并返回String类型;
3. 不满八个二进制位就补全;
public class Md5Utils {
/**
* md5加密方法
* @param password
* @return
*/
public static String md5Password(String password) {
try {
//得到一个信息摘要器
MessageDigest digest = MessageDigest.getInstance("md5");
byte[] result = digest.digest(password.getBytes());
StringBuffer buffer = new StringBuffer();
//把每一个byte做一个与运算0xff
for (byte b : result) {
//与运算
int number = b & 0xff; //加盐:int number = b & 0xfff;
String str = Integer.toHexString(number);
System.out.println(str);
if(str.length() == 1) {
buffer.append("0");
}
buffer.append(str);
}
//标准的md5加密后的结果
return buffer.toString();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
return null;
}
}
}
加盐运算:可以对参加与运算的数进行修改,如0xff修改为0xfff。
以上代码仅对原来的字符串做了一次运算,安全系数较低。若要提高安全系数,可以对加密后得到的字符串重复多次加密。