/*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();
		}
	}
}