算法步骤:
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。
以上代码仅对原来的字符串做了一次运算,安全系数较低。若要提高安全系数,可以对加密后得到的字符串重复多次加密。
本文深入解析密码加密算法的核心过程,包括将字符串转换为字节码,与固定值进行与运算,并将结果转换为16进制字符串。同时讨论了加盐运算对安全性的提升,并提出通过多次加密来进一步增强安全性。
840

被折叠的 条评论
为什么被折叠?



