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