问题:两种方式生成的md5串不匹配的问题
MAIN方法生成的:
871903B66AD9C3ED67CAD9C3D4214324
前端Controller生成的加密字符串:
6214869A27142CB8552AFA5D15742E84
md5方法:
public final static String MD5(String s) {
char hexDigits[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
try {
byte[] btInput = s.getBytes();
// 获得MD5摘要算法的 MessageDigest 对象
MessageDigest mdInst = MessageDigest.getInstance("MD5");
// 使用指定的字节更新摘要
mdInst.update(btInput);
// 获得密文
byte[] md = mdInst.digest();
// 把密文转换成十六进制的字符串形式
int j = md.length;
char str[] = new char[j * 2];
int k = 0;
for (int i = 0; i < j; i++) {
byte byte0 = md[i];
str[k++] = hexDigits[byte0 >>> 4 & 0xf];
str[k++] = hexDigits[byte0 & 0xf];
}
return new String(str);
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
问题处理:
原因是因为加密串存在中文的问题,只是编码方式不一样而以,一个是ANSI编码模式,一个是UTF-8编码模式;
在之是因为中文的问题,所以就先把中文进行加密,再对整个字符串进行加密,这样就可以解析加密串不一至的问题了。
解决方式来源于以下连接:
http://www.oschina.net/question/257867_147012?sort=time