Java密碼學信息摘要
散列函數非常有用,幾乎出現在所有信息安全應用程序中。
哈希函數是將數字輸入值轉換爲另一個壓縮數值的數學函數。 散列函數的輸入具有任意長度,但輸出始終具有固定長度。
散列函數返回的值稱爲信息摘要或簡稱散列值。 下圖說明了散列函數。
Java提供了一個名爲MessageDigest
的類,它屬於java.security
包。 此類支持諸如SHA-1
,SHA 256
,MD5
算法之類的算法,以將任意長度的消息轉換爲信息摘要。
要將給定郵件轉換爲郵件摘要,請按照以下步驟進行操作 -
第1步:創建MessageDigest對象
MessageDigest
類提供名爲getInstance()
的方法。 此方法接受String
變量,該變量指定要使用的算法的名稱,並返回實現指定算法的MessageDigest
對象。
使用getInstance()
方法創建MessageDigest
對象,如下所示 -
MessageDigest md = MessageDigest.getInstance("SHA-256");
第2步:將數據傳遞給創建的MessageDigest對象
創建消息摘要對象後,需要將消息/數據傳遞給它。 可以使用MessageDigest
類的update()
方法執行此操作,此方法接受表示消息的字節數組,並將其添加/傳遞給上面創建的MessageDigest
對象。
MessageDigest md = MessageDigest.getInstance("SHA-256");
md.update(msg.getBytes());
第3步:生成消息摘要
可以使用digest()
方法生成消息摘要,MessageDigest
類此方法計算當前對象的散列函數,並以字節數組的形式返回消息摘要。
使用摘要方法生成消息摘要。
MessageDigest md = MessageDigest.getInstance("SHA-256");
md.update(msg.getBytes());
byte[] digest = md.digest();
示例代碼
以下是從文件中讀取數據並生成消息摘要並打印出來的示例。
import java.security.MessageDigest;
import java.util.Scanner;
public class MessageDigestExample {
public static void main(String args[]) throws Exception{
//Reading data from user
Scanner sc = new Scanner(System.in);
System.out.println("Enter the message");
String message = sc.nextLine();
//Creating the MessageDigest object
MessageDigest md = MessageDigest.getInstance("SHA-256");
//Passing data to the created MessageDigest Object
md.update(message.getBytes());
//Compute the message digest
byte[] digest = md.digest();
System.out.println(digest);
//Converting the byte array in to HexString format
StringBuffer hexString = new StringBuffer();
for (int i = 0;i<digest.length;i++) {
hexString.append(Integer.toHexString(0xFF & digest[i]));
}
System.out.println("Hex format : " + hexString.toString());
}
}
編譯並執行上面示例代碼,得到以下結果:
Enter the message
Hello how are you
[B@55f96302
Hex format: 2953d33828c395aebe8225236ba4e23fa75e6f13bd881b9056a3295cbd64d3