欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

Java加密 消息摘要算法MAC实现详解

时间:2021-02-21 14:55:32|栏目:JAVA代码|点击:

MAC是消息摘要算法的第三种实现方式,另外两种方式分别为:MD2\4\5、SHA。

MAC的jdk实现:1、默认密钥方式

private static void MAC_JDK(){
  try {
   KeyGenerator keyGenerator = KeyGenerator.getInstance("HmacMD5");//初始化KeyGenerator
   SecretKey secretKey = keyGenerator.generateKey();//产生密钥
   byte[] key = secretKey.getEncoded();//获得默认密钥
   
   SecretKey restorSecretKey = new SecretKeySpec(key, "HmacMD5");//还原密钥
   Mac mac = Mac.getInstance(restorSecretKey.getAlgorithm());//示例化MAC
   mac.init(restorSecretKey);//初始化MAC
   byte[] hmacMD5Bytes = mac.doFinal(src.getBytes());//执行摘要
   System.out.println("hmacMD5Byte : "+Hex.encodeHexString(hmacMD5Bytes));
  } catch (Exception e) {
   e.printStackTrace();
  } 
 }

2、动态密钥方式:

private static void MAC_JDK_dongtai(){
  try {
   byte[] key = Hex.decodeHex(new char[]{'a','a','a','a','a','a','a','a','a','a'});//动态获得密钥
   
   SecretKey restorSecretKey = new SecretKeySpec(key, "HmacMD5");//还原密钥
   Mac mac = Mac.getInstance(restorSecretKey.getAlgorithm());//示例化MAC
   mac.init(restorSecretKey);//初始化MAC
   byte[] hmacMD5Bytes = mac.doFinal(src.getBytes());//执行摘要
   System.out.println("hmacMD5Byte : "+Hex.encodeHexString(hmacMD5Bytes));
  } catch (Exception e) {
   e.printStackTrace();
  } 
 }

MAC的BC实现:

private static void MAC_BC(){
  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[] mac_BC_Byte = new byte[hmac.getMacSize()];//执行摘要
  hmac.doFinal(mac_BC_Byte, 0);
  System.out.println("mac_BC_Byte : "+Hex.encodeHexString(mac_BC_Byte));
 }

到今天JAVA中的Base64、对称加密、消息摘要加密的实现总结就完工了,如果哪位对此感兴趣,还望多多交流。(1453296946@qq.com)

上一篇:java搭建一个Socket服务器响应多用户访问

栏    目:JAVA代码

下一篇:详解JAVA中使用FTPClient工具类上传下载

本文标题:Java加密 消息摘要算法MAC实现详解

本文地址:http://www.codeinn.net/misctech/67161.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有