问题描述
我目前正在将一些库从 .netstandard2.0 迁移到 .net5.0,并偶然发现了一个我无法真正理解的奇怪行为,即它在 .netstandard2.0 中可以正常工作,但在 .net5.0 中不再有效。我以前从未使用过任何加密代码,所以我可能会错过一些明显的点。
我能够将我的问题分解为以下几点:
var cpParams = new CspParameters { KeyContainerName = KEY_CONTAINER };
RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(cspParams);
rsa.ImportCspBlob(...);
byte[] signature = rsa.SignData(byteArray,new SHA1CryptoServiceProvider());
var isValid = rsa.VerifyData(byteArray,new SHA1CryptoServiceProvider(),signature)
isValid 显然应该是真的,我们也可以在 .netstandard2.0 中验证。
但是,迁移到 .net5.0 后,isValid 为 false。
我做了一些研究,但找不到任何解释。
有人对此有更深入的了解吗?
解决方法
我遇到了类似的问题。 CspParameters
将 KeyNumber
初始化为 -1
,后来,ImportCspBlob
将 KeyNumber
属性从 2
更改为 1
,无论出于何种原因.
尝试设置以下内容,ImportCspBlob
就会起作用。
CspParameters.KeyNumber = (int)KeyNumber.Signature