【java工具類】將明文密碼轉成MD5密碼

【java工具類】將明文密碼轉成MD5密碼

import java.security.MessageDigest;

/**
 * 寫一個MD5算法,運行結果與MySQL的md5()函數相同
 * 將明文密碼轉成MD5密碼
 * 123456->e10adc3949ba59abbe56e057f20f883e
 */
public final class Md5Util {
	private Md5Util(){}
	/**
	 * 將明文密碼轉成MD5密碼 
	 */
	public static String encodeByMd5(String password) throws Exception{
		//Java中MessageDigest類封裝了MD5和SHA算法,今天我們只要MD5算法
		MessageDigest md5 = MessageDigest.getInstance("MD5");
		//調用MD5算法,即返回16個byte類型的值
		byte[] byteArray = md5.digest(password.getBytes());
		//注意:MessageDigest只能將String轉成byte[],接下來的事情,由我們程序員來完成
		return byteArrayToHexString(byteArray);
	}
	/**
	 * 將byte[]轉在16進制字符串 
	 */
	private static String byteArrayToHexString(byte[] byteArray) {
		StringBuffer sb = new StringBuffer();
		//遍歷
		for(byte b : byteArray){//16次
			//取出每一個byte類型,進行轉換
			String hex = byteToHexString(b);
			//將轉換後的值放入StringBuffer中
			sb.append(hex);
		}
		return sb.toString();
	}
	/**
	 * 將byte轉在16進制字符串 
	 */
	private static String byteToHexString(byte b) {//-31轉成e1,10轉成0a,。。。
		//將byte類型賦給int類型
		int n = b;
		//如果n是負數
		if(n < 0){
			//轉正數
			//-31的16進制數,等價於求225的16進制數 
			n = 256 + n;
		}
		//商(14),數組的下標
		int d1 = n / 16;
		//餘(1),數組的下標
		int d2 = n % 16;
		//通過下標取值
		return hex[d1] + hex[d2];
	}
	private static String[] hex = {"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 password = "123456";
		String passwordMD5 = Md5Util.encodeByMd5(password);
		System.out.println(password);
		System.out.println(passwordMD5);
	}
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章