在Java中默认的md5加密采用的是MessageDigest的digest方法来加密。
代码如下:
String password = "123";
MessageDigest md = MessageDigest.getInstance("md5");
byte[] bs = md.digest(password.getBytes());
password = new String(bs);
以上代码会出现乱码问题。
添加一个进制转换的类,做如下修改:
class ByteUtil {
private final static char[] HEX = "0123456789abcdef".toCharArray();
/**
* 将字节数组转成 16 进制的字符串来表示,每个字节采用两个字符表表示
*
* @param bs 需要转换成 16 进制的字节数组
* @return
*/
public static String bytes2Hex(byte[] bys) {
char[] chs = new char[bys.length * 2];
for(int i = 0, offset = 0; i < bys.length; i++) {
chs[offset++] = HEX[bys[i] >> 4 & 0xf];
chs[offset++] = HEX[bys[i] & 0xf];
}
return new String(chs);
}
}
String password = "123";
MessageDigest md = MessageDigest.getInstance("md5");
byte[] bs = password.getBytes();
md.update(bs);
password = = ByteUtil.bytes2Hex(md.digest(bs));
现在就不会出现乱码