/*MD5加密密码存入数据库,可以一定防止假如数据库被破而不太影响用户密码问题,因为具有一定的不可逆转成原来的密码*/
package com.niit.test;
import java.io.UnsupportedEncodingException;
import java.security.*;
import java.util.logging.Level;
import java.util.logging.Logger;
public class TestMD5_2 {
public static void main(String[] args) {
String str = "0";
Md5(str);
System.out.println(str);
}
private static void Md5(String plainText) {
try {
// 返回实现指定摘要算法的 MessageDigest 对象
MessageDigest md = MessageDigest.getInstance("MD5");
// 使用指定的字节更新摘要
md.update(plainText.getBytes());
// 通过执行诸如填充之类的最终操作完成哈希计算
byte b[] = md.digest();
System.out.println(b);
int i;
StringBuffer buf = new StringBuffer("");
for (int offset = 0; offset < b.length; offset++) {
i = b[offset];
if (i < 0)
i += 256;
if (i < 16)
buf.append("0");
// 以十六进制(基数 16)无符号整数形式返回一个整数参数的字符串表示形式
buf.append(Integer.toHexString(i));
}
// 32位的加密
System.out.println("32位的加密result: " + buf.toString());
// 16位的加密
System.out.println("16位的加密result: " + buf.toString().substring(8, 24));
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}