MD5
Message Digest Algorithm MD5(中文名為消息摘要算法第五版)為計算機安全領域廣泛使用的一種散列函數(shù),用以提供消息的完整性保護。該算法的文件號為RFC 1321(R.Rivest,MIT Laboratory for Computer Science and RSA Data Security Inc. April 1992)。
MD5即Message-Digest Algorithm 5(信息-摘要算法5),用于確保信息傳輸完整一致。是計算機廣泛使用的雜湊算法之一(又譯摘要算法、哈希算法),主流編程語言普遍已有MD5實現(xiàn)。將數(shù)據(jù)(如漢字)運算為另一固定長度值,是雜湊算法的基礎原理,MD5的前身有MD2、MD3和MD4。
MD5算法具有以下特點:
1、壓縮性:任意長度的數(shù)據(jù),算出的MD5值長度都是固定的。
2、容易計算:從原數(shù)據(jù)計算出MD5值很容易。
3、抗修改性:對原數(shù)據(jù)進行任何改動,哪怕只修改1個字節(jié),所得到的MD5值都有很大區(qū)別。
4、強抗碰撞:已知原數(shù)據(jù)和其MD5值,想找到一個具有相同MD5值的數(shù)據(jù)(即偽造數(shù)據(jù))是非常困難的。
MD5的作用是讓大容量信息在用數(shù)字簽名軟件簽署私人密鑰前被"壓縮"成一種保密的格式(就是把一個任意長度的字節(jié)串變換成一定長的十六進制數(shù)字串)。除了MD5以外,其中比較有名的還有sha-1、RIPEMD以及Haval等。
Java實現(xiàn)加密
在Java中一些登入密碼的加密,需要用到MD5的加密技術
java.security.MessageDigest類用于為應用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。簡單點說就是用于生成散列碼。信息摘要是安全的單向哈希函數(shù),它接收任意大小的數(shù)據(jù),輸出固定長度的哈希值。
MessageDigest 通過其getInstance系列靜態(tài)函數(shù)來進行實例化和初始化。MessageDigest 對象通過使用 update 方法處理數(shù)據(jù)。任何時候都可以調(diào)用 reset 方法重置摘要。一旦所有需要更新的數(shù)據(jù)都已經(jīng)被更新了,應該調(diào)用 digest 方法之一完成哈希計算并返回結(jié)果。
對于給定數(shù)量的更新數(shù)據(jù),digest 方法只能被調(diào)用一次。digest 方法被調(diào)用后,MessageDigest 對象被重新設置成其初始狀態(tài)。
以下是根據(jù)上面MessageDigest,得出一個加密過程代碼實現(xiàn)
1
2
3
4
5
6
7
8
9
10
11
12
|
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(); } //返回大數(shù)據(jù)整型的,轉(zhuǎn)字符串 return new BigInteger( 1 , md.digest()).toString( 10 ); } |
以上這篇Java MD5加密(實例講解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:http://www.cnblogs.com/zhouguanglin/archive/2017/08/15/7362126.html