在用MD5进行签名校验的时候,发现我的MD5和别的有些结果是不同的,有时候比别人少了一位0.原因应该是java字节数组转16进制的时候0有可能没有补上。下面列举一下有问题的方法以及正确的方法。
有问题的MD5实现方法
public static String encode(String str) {MessageDigest digest;try {digest = MessageDigest.getInstance("MD5");digest.update(str.getBytes());return new BigInteger(1, digest.digest()).toString(16);} catch (NoSuchAlgorithmException e) {e.printStackTrace();return null;}}
正常的MD5方法
public 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("UTF-8");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;}}

