MD5加密例子
废话不多说,直接上代码
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class MD5Test {
public static void main(String[] args) throws NoSuchAlgorithmException, UnsupportedEncodingException {
// 1.声明一个字符串
String name = "sw";
// 2.获取md5加密算法的实例
MessageDigest md5 = MessageDigest.getInstance("MD5");
// 3.将字符串转化为字节数组
byte[] bytes = name.getBytes("utf-8");
// 4.调用md5的digest()方法进行加密,加密后的字节长度为16
byte[] md5bytes = md5.digest(bytes);
// 5.将加密后的字节数组转化为16进制、长度32的字符串
String md5Name = byte2hex(md5bytes);
// 6.打印输出
System.out.println(md5Name);
}
/**
* 将加密后的字节数组转化为16进制、长度32的字符串
* @param bytes 加密过的字节数组
* @return 返回一个16进制、长度32的字符串
*/
private static String byte2hex(byte[] bytes) {
StringBuffer sb = new StringBuffer();
String tmp = null;
// 遍历字节数组
for (int i = 0; i < bytes.length; i++) {
// 把每一个byte替换为16进制的两个位的数据,比如:把11转化为0c
tmp = Integer.toHexString(bytes[i] & 0XFF);
if (tmp.length() == 1) {// 字符串长度为1,说明这个数小于16,要在前面加上一个0填满两位
sb.append("0").append(tmp);
} else {
sb.append(tmp);
}
}
return sb.toString().toUpperCase();// 字母全部大写
}
}
运行结果: