.NET 中的 RSA 密钥指数有限制吗?

编程入门 行业动态 更新时间:2024-10-26 23:35:29
本文介绍了.NET 中的 RSA 密钥指数有限制吗?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧! 问题描述

使用 C# 我无法导入指数为 {1, 0, 0, 0, 15} 的公共 RSA 密钥:有一个例外:

Using C# I cannot import a public RSA key with an exponent of {1, 0, 0, 0, 15}: There is an exception:

System.Security.Cryptography.CryptographicException was caught HResult=-2146893819 Message=Bad Data. Source=mscorlib StackTrace: at System.Security.Cryptography.CryptographicException.ThrowCryptographicException(Int32 hr) at System.Security.Cryptography.Utils._ImportKey(SafeProvHandle hCSP, Int32 keyNumber, CspProviderFlags flags, Object cspObject, SafeKeyHandle& hKey) at System.Security.Cryptography.RSACryptoServiceProvider.ImportParameters(RSAParameters parameters) at TestRSA.Form1.buttonTest_Click(Object sender, EventArgs e) in c:UsersThomasDocumentsVisual Studio 2010ProjectsModulesTestRSAForm1.cs:line 32

使用代码:

RSACryptoServiceProvider rsaAlg = new RSACryptoServiceProvider(); RSAParameters key = new RSAParameters(); key.Exponent = new byte[5] { 1, 0, 0, 0, 15 }; key.Modulus = GetModulus(); // byte Array with length 256... rsaAlg.ImportParameters(key); // <<== this call will throw the exception

.NET 中的 RSA 密钥指数有限制吗?(使用 Exponent == { 1, 0, 1 } 导入将成功.

Is there a limit for RSA key exponents in .NET? (With Exponent == { 1, 0, 1 } the import will succeed.

问候托马斯

推荐答案

微软默认提供者只支持特定大小的公钥指数,CodesInChaos 认为:

The default provider by Microsoft only supports public key exponents of a specific size, as CodesInChaos mused:

CNG 在 RSA 密钥对方面更加灵活.例如,CNG 支持长度大于 32 位的公共指数,并且支持 p 和 q 长度不同的密钥.

CNG is more flexible with regard to RSA key pairs. For example, CNG supports public exponents larger than 32-bits in length, and it supports keys in which p and q are different lengths.

请注意,4 字节指数的限制仅适用于 MS CSP.如果使用第三方 CSP,CryptoAPI 应该能够使用 5 字节指数.

Please, note that the restriction of 4 byte exponents are for MS CSPs only. CryptoAPI should be able to work with 5 byte exponents if using a third-party CSP.

来源:

  • blogs.msdn/b/alejacma/archive/2010/07/28/cryptoapi-and-5-bytes-exponent-public-keys.aspx
  • 来源:msdn.microsoft/en-us/library/bb204778%28VS.85%29.aspx

更多推荐

.NET 中的 RSA 密钥指数有限制吗?

本文发布于:2023-10-17 11:07:34,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1500712.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:密钥   指数   NET   RSA

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!