gpt4 book ai didi

windows - 微软CSP : Difference between AT_SIGNATURE and RSA_KEY_SIGN (and also AT_KEYEXCHANGE and CALG_RSA_KEYX)

转载 作者:行者123 更新时间:2023-12-02 09:02:13 29 4
gpt4 key购买 nike

我正在为我公司销售的智能卡编写 CSP 库(用于 CryptoAPI)。

我对私钥的 AT_SIGNATURE key 类型和 CALG_RSA_SIGN 算法之间的差异有疑问(AT_KEYEXCHANGE 和 CALG_RSA_KEYX 也相同)。

我知道 MSDN 站点上写的是什么,但是如果在调用 CPGenKey() 函数时指定了 CALG_RSA... 算法中的任何一个,那么 CSP DLL 具体应该如何工作?我的意思是它应该生成 session RSA 私钥还是应该生成 key 并将其保存在卡上?或者也许它取决于 CPAcquireContext() 调用上指定的标志(即 CRYPT_VERIFY_CONTEXT ),并且 AT_SIGNATURE 应该定义为“签名的默认算法”,对于我们的卡来说是 RSA?

谢谢

最佳答案

这不是我的答案,只是找到了一个 good explanation在互联网上:

AT_SIGNATURE key acn ONLY be used to sign a message. It cannot be used to wrap (export) session key. AT_KEYEXCHANGE key can be used for BOTH purposes. So if you want to use only 1 (one) key pair for both, you definitely need AT_KEYEXCHANGE key pair.

You also need to understand some security implications - and why using two keys are better than using the same key pair for both:

Normally you should NEVER reveal your signing private key. If it is lost, you simply generate a new signing key pair and use that from that point of time. On the other hand, you normally need to back up your key exchange key, because without that you cannot decrypt messages in the future (if the private key is lost). However, backup means that the key may be available to someone else - who now could sign messages purportedly coming from you - and you wouldn't want that. If you use different key pairs for the two actions you can have secure signing (your signing private key never goes out) and still can back up your key exchange key.

One more note on generating these keys: Since you don't want your signing key know, when you generate it with CryptGenKey(AT_SIGNATURE) you should never set flags KEY_EXPORTABLE or KEY_ARCHIVABLE and you may want the extra protection and add CRYPT_USER_PROTECTED, so every time the signing key is used the user knows it. On the other hand, when generating the key exchange key using CryptGenKey(AT_KEYEXCHANGE) you should immediately back it up: set the flag CRYPT_ARCHIVABLE and IMMEDIATELY export the key for backup. (This flag allows to export the key only once - right after it is created -, so it is more secure than allowing to be exported any time by setting CRYPT_EXPORTABLE.)

Laszlo Elteto SafeNet, Inc.

关于windows - 微软CSP : Difference between AT_SIGNATURE and RSA_KEY_SIGN (and also AT_KEYEXCHANGE and CALG_RSA_KEYX),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3568695/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com