1. public static String md5Encode(String inputStr) {
  2. MessageDigest md5 = null;
  3. try {
  4. md5 = MessageDigest.getInstance("MD5");
  5. byte[] bytes = inputStr.getBytes("UTF-8");
  6. byte[] md5Bytes = md5.digest(bytes);
  7. StringBuffer hexValue = new StringBuffer();
  8. for (int i = 0; i < md5Bytes.length; i++) {
  9. int value = ((int) md5Bytes[i]) & 0xff;
  10. if (value < 16) {
  11. hexValue.append("0");
  12. }
  13. hexValue.append(Integer.toHexString(value));
  14. }
  15. return hexValue.toString();
  16. } catch (Exception e) {
  17. return "";
  18. }
  19. }

这里面再调用了加密算法完成之后,会返回byte数组,大小为16,最终生成的是32位的加密数据。总体的思路是把每一个byte替换为16进制的两个位的数据,至于为什么两位,是因为每个byte是8位的数据最大不会超过两位的十六进制的数据去。

那么这里之所以转为整形无非是整形的包装类中有Integer.toHexString()这个将其转为16进制的方法,如果Byte中有的话,估计这里是不会转为整形的。如果结果小于十六的时候,要再前面加上一个0填满两位的十六进制。

05-28 08:45