开发者社区> 问答> 正文

Java中的CMAC-AES(RFC 4493)计算

我有密钥和数据:

Keymac: 671B 9D1D C154 74A2 5CB1 77CA 1A19 9F0Eh
data: A3 0000 35E758C6 0900 4F4436F0EA319AF431E198BC41A067D1h

现在如何根据这些参数计算CMAC?

更多信息:

根据NIST特殊出版物800-38B中所述的CMAC标准,使用AES作为基础分组密码来计算MAC。但是我很难在Java中找到正确的MAC计算示例。

编辑 此链接对此非常有效。我需要此的Java示例。

问题来源:Stack Overflow

展开
收起
montos 2020-03-27 13:06:13 1263 0
1 条回答
写回答
取消 提交回答
  • 如果有人在这里寻找CMAC AES计算,那就是使用Bouncy Castle:

     public void getCMAC()
                throws Exception {
            byte[] msg = new byte[]{(byte) 0xA3, (byte) 0x00, (byte) 0x00, (byte) 0x35, (byte) 0xE7, (byte) 0x58,
                    (byte) 0xC6, (byte) 0x09, (byte) 0x00, (byte) 0x4F, (byte) 0x44, (byte) 0x36, (byte) 0xF0,
                    (byte) 0xEA, (byte) 0x31, (byte) 0x9A, (byte) 0xF4, (byte) 0x31, (byte) 0xE1,
                    (byte) 0x98, (byte) 0xBC, (byte) 0x41, (byte) 0xA0, (byte) 0x67, (byte) 0xD1};
    
            byte[] keydata = new byte[]{(byte) 0x67, (byte) 0x1B, (byte) 0x9D, (byte) 0x1D, (byte) 0xC1, (byte) 0x54,
                    (byte) 0x74, (byte) 0xA2, (byte) 0x5C, (byte) 0xB1, (byte) 0x77, (byte) 0xCA, (byte) 0x1A,
                    (byte) 0x19, (byte) 0x9F, (byte) 0x0E};
    
            CipherParameters params = new KeyParameter(keydata);
            BlockCipher aes = new AESEngine();
            CMac mac = new CMac(aes);
            mac.init(params);
            mac.update(msg, 0, msg.length);
            byte[] out = new byte[mac.getMacSize()];
            mac.doFinal(out, 0);
    
            StringBuilder s19 = new StringBuilder();
            for (byte b : out) {
                s19.append(String.format("%02X ", b));
            }
            Log.e("ecrypted Kmac :", s19.toString());
        }
        ```
    确保像这样添加lib:
    

    implementation 'org.bouncycastle:bcpkix-jdk15on:1.56'

    
    回答来源:Stack Overflow
    2020-03-27 13:06:41
    赞同 展开评论 打赏
问答标签:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
Spring Cloud Alibaba - 重新定义 Java Cloud-Native 立即下载
The Reactive Cloud Native Arch 立即下载
JAVA开发手册1.5.0 立即下载