📅  最后修改于: 2020-11-15 03:44:24             🧑  作者: Mango
MAC(M essage甲uthenticationÇODE)算法是对称密钥密码技术,以提供消息验证。为了建立MAC进程,发送方和接收方共享一个对称密钥K。
本质上,MAC是在基础消息上生成的加密校验和,并与消息一起发送以确保消息认证。
下图描述了使用MAC进行身份验证的过程-
在Java中, javax.crypto软件包的Mac类提供了消息身份验证代码的功能。请按照下面给出的步骤使用此类创建消息身份验证代码。
KeyGenerator类提供了getInstance()方法,该方法接受表示所需密钥生成算法的String变量,并返回生成秘密密钥的KeyGenerator对象。
如下所示,使用getInstance()方法创建KeyGenerator对象。
//Creating a KeyGenerator object
KeyGenerator keyGen = KeyGenerator.getInstance("DES");
java.Security包的SecureRandom类提供了一个强大的随机数生成器,该生成器用于在Java中生成随机数。实例化该类,如下所示。
//Creating a SecureRandom object
SecureRandom secRandom = new SecureRandom();
KeyGenerator类提供了一个名为init()的方法,该方法接受SecureRandom对象并初始化当前的KeyGenerator 。
使用此方法初始化在上一步中创建的KeyGenerator对象。
//Initializing the KeyGenerator
keyGen.init(secRandom);
使用KeyGenerator类的generateKey()方法生成密钥,如下所示。
//Creating/Generating a key
Key key = keyGen.generateKey();
Mac类的init()方法接受Key对象,并使用给定的键初始化当前的Mac对象。
//Initializing the Mac object
mac.init(key);
Mac类的doFinal()方法用于完成Mac操作。将所需的数据以字节数组的形式传递给此方法,并完成如下所示的操作。
//Computing the Mac
String msg = new String("Hi how are you");
byte[] bytes = msg.getBytes();
byte[] macResult = mac.doFinal(bytes);
下面的示例演示了使用JCA生成消息认证代码(MAC)的过程。在这里,我们收到一条简单的消息“嗨,你好吗”,并为该消息生成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{
//Creating a KeyGenerator object
KeyGenerator keyGen = KeyGenerator.getInstance("DES");
//Creating a SecureRandom object
SecureRandom secRandom = new SecureRandom();
//Initializing the KeyGenerator
keyGen.init(secRandom);
//Creating/Generating a key
Key key = keyGen.generateKey();
//Creating a Mac object
Mac mac = Mac.getInstance("HmacSHA256");
//Initializing the Mac object
mac.init(key);
//Computing the Mac
String msg = new String("Hi how are you");
byte[] bytes = msg.getBytes();
byte[] macResult = mac.doFinal(bytes);
System.out.println("Mac result:");
System.out.println(new String(macResult));
}
}
上面的程序将生成以下输出-
Mac result:
HÖ„^ǃÎ_Utbh…?š_üzØSSÜh_ž_œa0ŽV?