• Java加密2-MAC 对称密钥加密


    MAC( M essage A uessntication C ode)算法是一种对称密钥加密技术,用于提供消息认证。 为了建立MAC过程,发送方和接收方共享对称密钥K.

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

    使用MAC进行身份验证的过程如下图所示 -

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

    第1步:创建KeyGenerator对象

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

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

    1. //Creating a KeyGenerator object
    2. KeyGenerator keyGen = KeyGenerator.getInstance("DES");

    第2步:创建SecureRandom对象

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

    1. //Creating a SecureRandom object
    2. SecureRandom secRandom = new SecureRandom();

    第3步:初始化KeyGenerator

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

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

    1. //Initializing the KeyGenerator
    2. keyGen.init(secRandom);

    第4步:生成密钥

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

    1. //Creating/Generating a key
    2. Key key = keyGen.generateKey();

    第5步:初始化Mac对象

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

    1. //Initializing the Mac object
    2. mac.init(key);

    第6步:完成mac操作

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

    1. //Computing the Mac
    2. String msg = new String("Hi how are you");
    3. byte[] bytes = msg.getBytes();
    4. byte[] macResult = mac.doFinal(bytes);

    例子 (Example)

    以下示例演示如何使用JCA生成消息验证代码(MAC)。 在这里,我们收到一条简单的消息“你好,你好”,并为该消息生成一个Mac。

    1. import java.security.Key;
    2. import java.security.SecureRandom;
    3. import javax.crypto.KeyGenerator;
    4. import javax.crypto.Mac;
    5. public class MacSample {
    6. public static void main(String args[]) throws Exception{
    7. //Creating a KeyGenerator object
    8. KeyGenerator keyGen = KeyGenerator.getInstance("DES");
    9. //Creating a SecureRandom object
    10. SecureRandom secRandom = new SecureRandom();
    11. //Initializing the KeyGenerator
    12. keyGen.init(secRandom);
    13. //Creating/Generating a key
    14. Key key = keyGen.generateKey();
    15. //Creating a Mac object
    16. Mac mac = Mac.getInstance("HmacSHA256");
    17. //Initializing the Mac object
    18. mac.init(key);
    19. //Computing the Mac
    20. String msg = new String("Hi how are you");
    21. byte[] bytes = msg.getBytes();
    22. byte[] macResult = mac.doFinal(bytes);
    23. System.out.println("Mac result:");
    24. System.out.println(new String(macResult));
    25. }
    26. }

     

  • 相关阅读:
    [python][nginx][https] Nginx 服务器 SSL 证书安装部署
    2022年8月叙利亚再次因国考全国断网
    Java 并发编程面试题——BlockingQueue
    笔试强训第18天
    azure devops工具实践分析
    Jenkins系列之pipeline语法介绍与案例
    一步搞懂镜像文件
    Redis核心数据结构【set】【从入门到入坟】
    LINUX 基础
    属性和字段的区别
  • 原文地址:https://blog.csdn.net/u011016373/article/details/126117205