Różne sygnatury S / MIME między OpenSSL a C #

Próbuję użyć kodu OpenSSL w moim programie .Net. Oto kod:

openssl pkcs12 -in "My PassKit Cert.p12" -clcerts -nokeys -out certificate.pem
openssl pkcs12 -in "My PassKit Cert.p12" -nocerts -out key.pem
smime -binary -sign -signer certificate.pem -inkey key.pem -in manifest.json -out signature -outform DER

Próbowałem użyć .Net OpenSSL, ale absolutnie nie mam pojęcia, jak z niego korzystać i nie mogłem znaleźć dobrej dokumentacji. Postanowiłem użyć .Net do wykonania tego samego procesu znakowania, oto kod:

var dataToSign = System.IO.File.ReadAllBytes(filePathToSign);
ContentInfo contentInfo = new ContentInfo(dataToSign);

X509Certificate2 signerCert = new X509Certificate2(System.IO.File.ReadAllBytes(signerPfxCertPath), signerPfxCertPassword);

var signedCms = new SignedCms(contentInfo, true);
var signer = new CmsSigner(SubjectIdentifierType.IssuerAndSerialNumber, signerCert);

signer.IncludeOption = X509IncludeOption.EndCertOnly;
signedCms.ComputeSignature(signer);

var myCmsMessage = signedCms.Encode();

var buf = Encoding.Convert(Encoding.UTF7, Encoding.UTF8, myCmsMessage);

return Encoding.UTF8.GetString(buf, 0, buf.Length);

Ale wyniki między C # i OpenSSL nie są takie same. Czy ktoś mógłby mi pomóc?

Z góry dziękuję!

questionAnswers(1)

yourAnswerToTheQuestion