• C# 生成自签名CA证书


                         string password = "213978863940714";
                        string signatureAlgorithm = "SHA1WithRSA";
    
                        // Generate RSA key pair
                        var rsaGenerator = new RsaKeyPairGenerator();
                        var randomGenerator = new CryptoApiRandomGenerator();
                        var secureRandom = new SecureRandom(randomGenerator);
                        var keyParameters = new KeyGenerationParameters(secureRandom, 1024);
                        rsaGenerator.Init(keyParameters);
                        var keyPair = rsaGenerator.GenerateKeyPair();
    
                        // Generate certificate
                        var attributes = new Hashtable();
                        attributes[X509Name.E] = UserInfo.idCard;//设置dn信息的邮箱地址
                        attributes[X509Name.CN] = UserInfo.idCard;//设置证书的用户,也就是颁发给谁
                        attributes[X509Name.O] = "www.shwdztc.com";//设置证书的办法者
                        attributes[X509Name.C] = "Zh";//证书的语言
    
                        //这里是证书颁发者的信息
                        var ordering = new ArrayList();
                        ordering.Add(X509Name.E);
                        ordering.Add(X509Name.CN);
                        ordering.Add(X509Name.O);
                        ordering.Add(X509Name.C);
    
                        var certificateGenerator = new X509V3CertificateGenerator();
                        //设置证书序列化号
                        certificateGenerator.SetSerialNumber(BigInteger.ProbablePrime(120, new Random()));
    
    
                        //设置颁发者dn信息
                        certificateGenerator.SetIssuerDN(new X509Name(ordering, attributes));
    
    
                        //设置证书生效时间
                        certificateGenerator.SetNotBefore(DateTime.Today.Subtract(new TimeSpan(1, 0, 0, 0)));
                        //设置证书失效时间
                        certificateGenerator.SetNotAfter(DateTime.Today.AddDays(365));
                        //设置接受者dn信息
                        certificateGenerator.SetSubjectDN(new X509Name(ordering, attributes));
                        //设置证书的公钥
                        certificateGenerator.SetPublicKey(keyPair.Public);
    
    
    
                        //设置证书的加密算法
                        certificateGenerator.SetSignatureAlgorithm(signatureAlgorithm);
                        certificateGenerator.AddExtension(X509Extensions.BasicConstraints, true, new BasicConstraints(false));
                        certificateGenerator.AddExtension(X509Extensions.AuthorityKeyIdentifier, true, new AuthorityKeyIdentifier(SubjectPublicKeyInfoFactory.CreateSubjectPublicKeyInfo(keyPair.Public)));
    
    
                        certificateGenerator.AddExtension(X509Extensions.ExtendedKeyUsage.Id, false, new ExtendedKeyUsage(new ArrayList() { new DerObjectIdentifier("1.3.6.1.5.5.7.3.2") }));
    
    
    
                        //创建证书,如果需要cer格式的证书,到这里就可以了。如果是pfx格式的就需要加上访问密码
                        var x509Certificate = certificateGenerator.Generate(keyPair.Private);
    
    
    
    
    
    
                        byte[] pkcs12Bytes = DotNetUtilities.ToX509Certificate(x509Certificate).Export(X509ContentType.Pfx, password);
    
                        var certificate = new X509Certificate2(pkcs12Bytes, password);
    
                        certificate.PrivateKey = EncryHelper.ToDotNetKey((RsaPrivateCrtKeyParameters)keyPair.Private);
    
    
                        var array = certificate.Export(X509ContentType.Pfx, password);
    
                        var cerArray = certificate.Export(X509ContentType.Cert);
    
    
    
                        string path = HttpContext.Current.Server.MapPath("~/files/userword/Word/" + UserInfo.idCard + ".pfx");
                        string pathcer = HttpContext.Current.Server.MapPath("~/files/userword/Word/" + UserInfo.idCard + ".cer");
    
                        FileStream fsCA = new FileStream(path, FileMode.Create);
                        //将byte数组写入文件中
                        fsCA.Write(array, 0, array.Length);
                        fsCA.Close();
    
                        FileStream fscer = new FileStream(pathcer, FileMode.Create);
                        //将byte数组写入文件中
                        fscer.Write(cerArray, 0, cerArray.Length);
                        fscer.Close();
  • 相关阅读:
    BZOJ_1221_ [HNOI2001]_软件开发(最小费用流,网络流24题#10)
    POJ_1269_Intersecting_Lines_(计算几何基础)
    BZOJ_2049_[Sdoi_2008]_Cave_洞穴勘测_(LCT/并查集)
    BZOJ_2002_弹飞绵羊_(LCT)
    BZOJ_3282_Tree_(LCT)
    CodeForces_#354_Div.2_2016.5.25(A+B+C)
    BZOJ_1609_[Usaco2008_Feb]_Eating_Together_麻烦的聚餐_(动态规划,LIS)
    BZOJ_1607_ [Usaco2008_Dec]_Patting_Heads_轻拍牛头_(筛数)
    BZOJ_1606_ [Usaco2008_Dec]_Hay_For_Sale _购买干草_(背包)
    2010多校第一题 hdu3440House Man 差分约束系统
  • 原文地址:https://www.cnblogs.com/myshowtime/p/6281719.html
Copyright © 2020-2023  润新知