RSA验证签名

本文介绍了如何使用BC库来验证RSA签名,涵盖了证书文件和P7的处理过程,详细阐述了证书验证和签名检查的关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用BC实现证书文件及P7验证RSA签名

证书文件:

public bool Verify(string strPemCert, string strPemSignature, string strPlain)
...
byte[] btSignature = Convert.FromBase64String(strPemSignature);
byte[] btPlain = Encoding.ASCII.GetBytes(strPlain);
byte[] btCert = Convert.FromBase64String(strPemCert);
X509CertificateStructure x509 = X509CertificateStructure.GetInstance(Asn1Object.FromByteArray(btCert));
AsymmetricKeyParameter pubKey = PublicKeyFactory.CreateKey(x509.SubjectPublicKeyInfo);

ISigner signer = SignerUtilities.GetSigner("1.2.840.113549.1.1.5");
signer.Init(false, pubKey);
signer.BlockUpdate(btPlain, 0, btPlain.Length);
Boolean bVerify = signer.VerifySignature(btSignature);
...

P7:

public bool Verify(String strSignedData, String strPlain)
...                
byte[] btSignedData = Convert.FromBase64String(strSignedData);
DerSequence seq = (DerSequence)Asn1Object.FromByteArray(btSignedData);
DerTaggedObject content = (DerTaggedObject)seq[1];
SignedData signData = SignedData.GetInstance(content.GetObject());

DerOctetString octString = (DerOctetString)signData.ContentInfo.Content;
String sig = Encoding.Unicode.GetString(octString.GetOctets());
if (sig == null && !sig.Equals(strPlain))
{
    throw new Exception("INFO_VERIFY_PLAIN_FAIL");
}

SignerInfo signerInfo = SignerInfo.GetInstance(signData.SignerInfos[0]);
byte[] btPlain = signerInfo.AuthenticatedAttributes.GetEncoded("DER");
DerOctetString octSignature = (DerOctetString)signerInfo.EncryptedDigest;
byte[] btSignature = octSignature.GetOctets();
byte[] btCert = signData.Certificates[0].GetDerEncoded();
X509CertificateStructure x509 = X509CertificateStructure.GetInstance(Asn1Object.FromByteArray(btCert));
AsymmetricKeyParameter pubKey = PublicKeyFactory.CreateKey(x509.SubjectPublicKeyInfo);

ISigner signer = SignerUtilities.GetSigner("1.2.840.113549.1.1.5");
signer.Init(false, pubKey);
signer.BlockUpdate(btPlain, 0, btPlain.Length);
Boolean bVerify = signer.VerifySignature(btSignature);
...

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值