java md5加密結果不一至的問題
問題:兩種方式生成的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