Java消息摘要算法MAC實現(xiàn)與應(yīng)用的示例分析,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
10年積累的網(wǎng)站設(shè)計、網(wǎng)站建設(shè)經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先做網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有云安免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
下面實例講述了Java消息摘要算法MAC實現(xiàn)與應(yīng)用。分享給大家供大家參考,具體如下:
一 介紹
MAC:Message Authentication CodeHMAC:keyed-Hash Message Authencication Code,含有密鑰的散列函數(shù)算法。
融合MD、SHA
MD系列:HmacMD2、HmacMD4、HmacMD5
SHA系列:HmacSHA1、HmacSHA224、HmacSHA256、HmacSHA384、HmacSHA512
應(yīng)用:SecureCRT
二 參數(shù)說明
三 代碼實現(xiàn)
package com.imooc.security.hmac;import javax.crypto.KeyGenerator;
import javax.crypto.Mac;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import org.apache.commons.codec.binary.Hex;
import org.bouncycastle.crypto.digests.MD5Digest;
import org.bouncycastle.crypto.macs.HMac;
import org.bouncycastle.crypto.params.KeyParameter;
public class ImoocHmac {
private static String src = "cakin24 security hmac";
public static void main(String[] args) { jdkHmacMD5();
bcHmacMD5();
}
public static void jdkHmacMD5() {
try {
KeyGenerator keyGenerator = KeyGenerator.getInstance("HmacMD5");
//初始化KeyGenerator
SecretKey secretKey = keyGenerator.generateKey();
//產(chǎn)生密鑰//
byte[] key = secretKey.getEncoded();
//獲得密鑰
byte[] key = Hex.decodeHex(new char[] {'a', 'a', 'a', 'a', 'a', 'a', 'a', 'a', 'a', 'a'});
SecretKey restoreSecretKey = new SecretKeySpec(key, "HmacMD5");
//還原密鑰
Mac mac = Mac.getInstance(restoreSecretKey.getAlgorithm());
//實例化MAC
mac.init(restoreSecretKey);
//初始化Mac
byte[] hmacMD5Bytes = mac.doFinal(src.getBytes());
//執(zhí)行摘要
System.out.println("jdk hmacMD5 : " + Hex.encodeHexString(hmacMD5Bytes));
}
catch (Exception e) { e.printStackTrace();
} }
public static void bcHmacMD5() {
HMac hmac = new HMac(new MD5Digest());
hmac.init(new KeyParameter(org.bouncycastle.util.encoders.Hex.decode("aaaaaaaaaa"))); hmac.update(src.getBytes(), 0, src.getBytes().length);
byte[] hmacMD5Bytes = new byte[hmac.getMacSize()];
//執(zhí)行摘要
hmac.doFinal(hmacMD5Bytes, 0);
System.out.println("bc hmacMD5 : " + org.bouncycastle.util.encoders.Hex.toHexString(hmacMD5Bytes));
}}
四 實現(xiàn)效果
jdk hmacMD5 : d23aa029b2bacdd3979d10f0931f9af6bc hmacMD5 : d23aa029b2bacdd3979d10f0931f9af6
看完上述內(nèi)容,你們掌握J(rèn)ava消息摘要算法MAC實現(xiàn)與應(yīng)用的示例分析的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!