Java加密 消息摘要算法MAC实现详解
MAC是消息摘要算法的第三种实现方式,另外两种方式分别为:MD2\4\5、SHA。
MAC的jdk实现:1、默认密钥方式
privatestaticvoidMAC_JDK(){
try{
KeyGeneratorkeyGenerator=KeyGenerator.getInstance("HmacMD5");//初始化KeyGenerator
SecretKeysecretKey=keyGenerator.generateKey();//产生密钥
byte[]key=secretKey.getEncoded();//获得默认密钥
SecretKeyrestorSecretKey=newSecretKeySpec(key,"HmacMD5");//还原密钥
Macmac=Mac.getInstance(restorSecretKey.getAlgorithm());//示例化MAC
mac.init(restorSecretKey);//初始化MAC
byte[]hmacMD5Bytes=mac.doFinal(src.getBytes());//执行摘要
System.out.println("hmacMD5Byte:"+Hex.encodeHexString(hmacMD5Bytes));
}catch(Exceptione){
e.printStackTrace();
}
}
2、动态密钥方式:
privatestaticvoidMAC_JDK_dongtai(){
try{
byte[]key=Hex.decodeHex(newchar[]{'a','a','a','a','a','a','a','a','a','a'});//动态获得密钥
SecretKeyrestorSecretKey=newSecretKeySpec(key,"HmacMD5");//还原密钥
Macmac=Mac.getInstance(restorSecretKey.getAlgorithm());//示例化MAC
mac.init(restorSecretKey);//初始化MAC
byte[]hmacMD5Bytes=mac.doFinal(src.getBytes());//执行摘要
System.out.println("hmacMD5Byte:"+Hex.encodeHexString(hmacMD5Bytes));
}catch(Exceptione){
e.printStackTrace();
}
}
MAC的BC实现:
privatestaticvoidMAC_BC(){
HMachmac=newHMac(newMD5Digest());
hmac.init(newKeyParameter(org.bouncycastle.util.encoders.Hex.decode("aaaaaaaaaa")));
hmac.update(src.getBytes(),0,src.getBytes().length);
byte[]mac_BC_Byte=newbyte[hmac.getMacSize()];//执行摘要
hmac.doFinal(mac_BC_Byte,0);
System.out.println("mac_BC_Byte:"+Hex.encodeHexString(mac_BC_Byte));
}
到今天JAVA中的Base64、对称加密、消息摘要加密的实现总结就完工了,如果哪位对此感兴趣,还望多多交流。(1453296946@qq.com)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
