Hier ist ein Code, den Sie verwenden können:
static X509Certificate2 GenerateCertificate(string certName)
{
var keypairgen = new RsaKeyPairGenerator();
keypairgen.Init(new KeyGenerationParameters(new SecureRandom(new CryptoApiRandomGenerator()), 1024));
var keypair = keypairgen.GenerateKeyPair();
var gen = new X509V3CertificateGenerator();
var CN = new X509Name("CN=" + certName);
var SN = BigInteger.ProbablePrime(120, new Random());
gen.SetSerialNumber(SN);
gen.SetSubjectDN(CN);
gen.SetIssuerDN(CN);
gen.SetNotAfter(DateTime.MaxValue);
gen.SetNotBefore(DateTime.Now.Subtract(new TimeSpan(7, 0, 0, 0)));
gen.SetSignatureAlgorithm("MD5WithRSA");
gen.SetPublicKey(keypair.Public);
var newCert = gen.Generate(keypair.Private);
return new X509Certificate2(DotNetUtilities.ToX509Certificate((Org.BouncyCastle.X509.X509Certificate)newCert));
}
für diese zu arbeiten, vergessen Sie nicht Bezug auf BouncyCastle library
hinzuzufügen scheint dies niemand wissen. Scheint, dass x509Certificate2 in .net nur zum Lesen von x509Certificate2-Zertifikaten dient, anstatt solche zu generieren, oder? – travellover
Ja, mit Methode und Konstruktor, die X509Certificate2 haben, können wir nur importieren und seine Eigenschaften erhalten. – pinichi