总结:使用DigestUtils的方法加密的结果与messageDigest的方法加密结果一致,可使用DigestUtils替换MessageDigest 可省掉部分代码
1 package com.action;
2
3 import java.security.MessageDigest;
4
5 import org.apache.commons.codec.digest.DigestUtils;
6
7 public class Hello {
8
9 private static final char[] HEX_DIGITS = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
10
11 public static void main(String[] args) throws Exception {
12 String testStr = "baichuanyu12";
13
14 //使用DigestUtils进行md5加密 需要引入 commons-codec.jar
15 String md5Result = DigestUtils.md5Hex(testStr.getBytes());
16 System.out.println(md5Result);
17 //使用DigestUtils进行sha1加密
18 String sha1Result = DigestUtils.shaHex(testStr.getBytes());
19 System.out.println(sha1Result);
20
21 //使用MessageDigest进行MD5加密
22 MessageDigest md = MessageDigest.getInstance("MD5");
23 md.update(testStr.getBytes());
24 String md5 = getFormattedText(md.digest());
25 System.out.println(md5);
26 //使用MessageDigest进行SHA1加密
27 MessageDigest md_sha = MessageDigest.getInstance("SHA-1");
28 md_sha.update(testStr.getBytes());
29 String sha1 = getFormattedText(md_sha.digest());
30 System.out.println(sha1);
31 }
32
33 // 加密算法 把密文转成16进制的字符串形式
34 public static String getFormattedText(byte[] bytes) {
35 int len = bytes.length;
36 StringBuilder buf = new StringBuilder(len * 2);
37 for (int j = 0; j < len; j++) {
38 buf.append(HEX_DIGITS[(bytes[j] >> 4) & 0x0f]);
39 buf.append(HEX_DIGITS[bytes[j] & 0x0f]);
40 }
41 return buf.toString();
42 }
43 }