无涯教程-Java Md5 - 创建MAC

83 阅读2分钟

MAC( M 消息 A 复通 C 代码)算法是一种用于提供消息身份验证的对称密钥加密技术。为了创建MAC进程,发送方和接收方共享一个对称密钥K。

本质上,MAC是在基础消息上生成的加密校验和,与消息一起发送以确保消息认证。

下图描述了使用MAC进行身份验证的过程-

Creating MAC

在Java中, javax.crypto 包的 Mac 类提供了消息身份验证代码的功能。请按照下面给出的步骤使用此类创建消息身份验证代码。

步骤1 - 创建KeyGenerator对象

KeyGenerator 类提供 getInstance()方法,该方法接受表示所需密钥生成算法的String变量,并返回生成秘密密钥的 KeyGenerator 对象 。

使用 getInstance()方法创建 KeyGenerator 对象 ,如下所示。

//创建 KeyGenerator 对象
KeyGenerator keyGen=KeyGenerator.getInstance("DES");

步骤2 - 创建SecureRandom对象

java.Security 包的 SecureRandom 类提供了一个强大的随机数生成器,该生成器用于在Java中生成随机数。实例化此类,如下所示。

//创建 SecureRandom 对象
SecureRandom secRandom=new SecureRandom();

步骤3 - 初始化KeyGenerator

KeyGenerator 类提供了一个名为 init()的方法,该方法接受 SecureRandom对象 并初始化当前的 KeyGenerator 。

使用此方法初始化在上一步中创建的KeyGenerator 对象 。

//初始化密钥生成器
keyGen.init(secRandom);

步骤4 - 产生Key密钥

使用 KeyGenerator 类的 generateKey()方法生成密钥,如下所示。

//创建/生成密钥
Key key=keyGen.generateKey();

步骤5 - 初始化Mac对象

Mac类的 init()方法接受一个Key对象 ,并使用给定的键初始化当前的Mac对象 。

//初始化 Mac 对象
mac.init(key);

步骤6 - 完成mac操作

Mac类的 doFinal()方法用于完成Mac操作。将所需的数据以字节数组的形式传递给此方法,并完成如下所示的操作。

//计算 Mac
String msg=new String("Hi how are you");
byte[] bytes=msg.getBytes();
byte[] macResult=mac.doFinal(bytes);

MAC示例

下面的示例演示了使用JCA生成消息认证代码(MAC)的过程。在这里,无涯教程收到一条简单的消息"Hi how are you",并为该消息生成Mac。

import java.security.Key;
import java.security.SecureRandom;

import javax.crypto.KeyGenerator; import javax.crypto.Mac;

public class MacSample { public static void main(String args[]) throws Exception{ //创建 KeyGenerator 对象 KeyGenerator keyGen = KeyGenerator.getInstance("DES");

  </span><span class="com">//创建 SecureRandom 对象</span><span class="pln">
  </span><span class="typ">SecureRandom</span><span class="pln"> secRandom </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">SecureRandom</span><span class="pun">();</span><span class="pln">

  </span><span class="com">//初始化密钥生成器</span><span class="pln">
  keyGen</span><span class="pun">.</span><span class="pln">init</span><span class="pun">(</span><span class="pln">secRandom</span><span class="pun">);</span><span class="pln">

  </span><span class="com">//创建/生成密钥</span><span class="pln">
  </span><span class="typ">Key</span><span class="pln"> key </span><span class="pun">=</span><span class="pln"> keyGen</span><span class="pun">.</span><span class="pln">generateKey</span><span class="pun">();</span><span class="pln">	 

  </span><span class="com">//创建 Mac 对象</span><span class="pln">
  </span><span class="typ">Mac</span><span class="pln"> mac </span><span class="pun">=</span><span class="pln"> </span><span class="typ">Mac</span><span class="pun">.</span><span class="pln">getInstance</span><span class="pun">(</span><span class="str">"HmacSHA256"</span><span class="pun">);</span><span class="pln">

  </span><span class="com">//初始化 Mac 对象</span><span class="pln">
  mac</span><span class="pun">.</span><span class="pln">init</span><span class="pun">(</span><span class="pln">key</span><span class="pun">);</span><span class="pln">

  </span><span class="com">//计算 Mac</span><span class="pln">
  </span><span class="typ">String</span><span class="pln"> msg </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">String</span><span class="pun">(</span><span class="str">"Hi how are you"</span><span class="pun">);</span><span class="pln">
  </span><span class="kwd">byte</span><span class="pun">[]</span><span class="pln"> bytes </span><span class="pun">=</span><span class="pln"> msg</span><span class="pun">.</span><span class="pln">getBytes</span><span class="pun">();</span><span class="pln">      
  </span><span class="kwd">byte</span><span class="pun">[]</span><span class="pln"> macResult </span><span class="pun">=</span><span class="pln"> mac</span><span class="pun">.</span><span class="pln">doFinal</span><span class="pun">(</span><span class="pln">bytes</span><span class="pun">);</span><span class="pln">

  </span><span class="typ">System</span><span class="pun">.</span><span class="kwd">out</span><span class="pun">.</span><span class="pln">println</span><span class="pun">(</span><span class="str">"Mac result:"</span><span class="pun">);</span><span class="pln">
  </span><span class="typ">System</span><span class="pun">.</span><span class="kwd">out</span><span class="pun">.</span><span class="pln">println</span><span class="pun">(</span><span class="kwd">new</span><span class="pln"> </span><span class="typ">String</span><span class="pun">(</span><span class="pln">macResult</span><span class="pun">));</span><span class="pln">     

} }

上面的程序将生成以下输出-

Mac result:
HÖ„^ǃÎ_Utbh…?š_üzØSSÜh_ž_œa0ŽV?

参考链接

www.learnfk.com/java-crypto…