首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Pkcs11Interop (C#) -在Utimaco HSM模拟器上计算HMAC签名

Pkcs11Interop (C#) -在Utimaco HSM模拟器上计算HMAC签名
EN

Stack Overflow用户
提问于 2021-02-07 11:33:04
回答 1查看 446关注 0票数 0

我必须在Utimaco HSM模拟器上生成带有AES-256密钥的HMAC(SHA256)签名。为此,我使用PKCS#11库"Pkcs11Interop“(C#)。我的源代码功能:

代码语言:javascript
复制
public static byte[] GetSignatureHmacSha256(IObjectHandle secretKeyHandle, byte[] message)
        {
            ICkMacGeneralParams macParams = Settings.Factories.MechanismParamsFactory.CreateCkMacGeneralParams(32);            
            IMechanism mechanism = session.Factories.MechanismFactory.Create(CKM.CKM_SHA256_HMAC_GENERAL, macParams);
            byte[] signature = session.Sign(mechanism, secretKeyHandle, message);            
            return signature;
        }

我收到了这条错误信息。有人能帮我一下我做错什么了吗?

“方法C_SignInit返回CKR_MECHANISM_INVALID"

Utimaco日志:“机制CKM_SHA256_HMAC_GENERAL不适合键t”

EN

回答 1

Stack Overflow用户

发布于 2021-02-07 22:26:19

对于HMAC,您需要使用以下之一:

  • 通用密钥(CKK_GENERIC_SECRET)
  • 指定HMAC-HMAC 256密钥(CKK_SHA256_HMAC)

不能使用AES密钥(CKK_AES) --引用PKCS#11标准中的HMAC机制节:

HMAC密钥应对应于PKCS11通用密钥类型或机制特定密钥类型(请参阅机制定义)。这些键,用于HMAC操作,可以使用C_CreateObject或C_GenerateKey创建。

只需生成或导入CKK_GENERIC_SECRETCKK_SHA256_HMAC格式的HMAC键即可。

祝你的项目好运!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66087416

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档