使用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);
De