MD5 Message Digest Algorithm MD5(中文名為消息摘要演算法第五版)為電腦安全領域廣泛使用的一種散列函數,用以提供消息的完整性保護。該演算法的文件號為RFC 1321(R.Rivest,MIT Laboratory for Computer Science and RSA ...
-
MD5
MD5演算法具有以下特點:
1、壓縮性:任意長度的數據,算出的MD5值長度都是固定的。 2、容易計算:從原數據計算出MD5值很容易。 3、抗修改性:對原數據進行任何改動,哪怕只修改1個位元組,所得到的MD5值都有很大區別。 4、強抗碰撞:已知原數據和其MD5值,想找到一個具有相同MD5值的數據(即偽造數據)是非常困難的。 MD5的作用是讓大容量信息在用數字簽名軟體簽署私人密鑰前被"壓縮"成一種保密的格式(就是把一個任意長度的位元組串變換成一定長的十六進位數字串)。除了MD5以外,其中比較有名的還有sha-1、RIPEMD以及Haval等。Java實現加密
在Java中一些登入密碼的加密,需要用到MD5的加密技術 java.security.MessageDigest類用於為應用程式提供信息摘要演算法的功能,如 MD5 或 SHA 演算法。簡單點說就是用於生成散列碼。信息摘要是安全的單向哈希函數,它接收任意大小的數據,輸出固定長度的哈希值。 MessageDigest 通過其getInstance系列靜態函數來進行實例化和初始化。MessageDigest 對象通過使用update
方法處理數據。任何時候都可以調用 reset
方法重置摘要。一旦所有需要更新的數據都已經被更新了,應該調用 digest
方法之一完成哈希計算並返回結果。
對於給定數量的更新數據,digest
方法只能被調用一次。digest
方法被調用後,MessageDigest 對象被重新設置成其初始狀態。
以下是根據上面MessageDigest,得出一個加密過程代碼實現
public static String getMd5( String pwd) { MessageDigest md=null; try { md=MessageDigest.getInstance("md5"); md.update(pwd.getBytes()); } catch (NoSuchAlgorithmException e) { // TODO Auto-generated catch block e.printStackTrace(); } //返回大數據整型的,轉字元串 return new BigInteger(1, md.digest()).toString(10); }