本文實例講述了Java實現MD5加密的方法。分享給大家供大家參考。具體實現方法如下:
import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class MD5HashUtil { private MessageDigest md = null; private static MD5HashUtil md5 = null; private static final char[] hexChars ={'0','1','2 ','3','4','5','6','7','8','9','A','B','C','D','E', 'F'}; /** * Constructor is private so you must use the getInstance method */ private MD5HashUtil() throws NoSuchAlgorithmException { md = MessageDigest.getInstance("MD5"); } /** * This returns the singleton instance * / public static MD5HashUtil getInstance()throws NoSuchAlgorithmException { if (md5 == null) { md5 = new MD5HashUtil(); } return (md5); } public static String hashCode(String dataToHash) throws NoSuchAlgorithmException{ return getInstance().hashData( dataToHash.getBytes()); } public static String hashCode(byte[] dataToHash) throws NoSuchAlgorithmException{ return getInstance().hashData(dataToHash); } public String hashData(byte[] dataToHash) { return hexStringFromBytes((calculateHash(dataToHash) )).toLowerCase(); } private byte[] calculateHash(byte[] dataToHash) { md.update(dataToHash, 0, dataToHash.length); return (md.digest()); } public String hexStringFromBytes(byte[] b) { String hex = ""; int msb; int lsb = 0; int i; // MSB maps to idx 0 for (i = 0; i < b.length; i++) { msb = ((int)b[ i] & 0x000000FF) / 16; lsb = ((int)b[i] & 0x000000FF) % 16; hex = hex + hexChars[msb] + hexChars[lsb]; } return(hex); } public static void main( String args[]) throws NoSuchAlgorithmException { String string = "my name is zhangli"; System.out.println(string); System.out.println(hashCode(string)); } }
如上代碼為java語言實現md5加密算法,輸出為加密後的密文!
通常將加密後的密文保存在數據庫中,如果需要比較只比較他們的用md5加密過後的密文。
同時,md5加密算法是不可逆的,破解的難度很高,雖然有人破解了md5,但是他們所用的硬件環境不是我們普通的計算機所比擬的,山大的一位很牛的女教授也破解了md5,不過不怎麼了解
希望本文所述對大家的java程序設計有所幫助。