美文网首页安全
PKCS#10 以及证书颁发过程

PKCS#10 以及证书颁发过程

作者: Astrophel_06c5 | 来源:发表于2018-04-18 18:46 被阅读0次

一、证书颁发

1.单证书的签发

  1. 用户填写信息注册(或者由RA的业务操作员注册用户)。
  2. 用户信息传递到RA。
  3. RA审核通过。
  4. 用户请求发证。
  5. RA审核通过。
  6. 用户签发证书请求。
  7. RA把用户信息传递到CA。
  8. CA到KMC中取密钥对,(密钥对由加密机生成,生成的密钥对)。
  9. CA把用户信息和从KMC中取到的公钥制作成证书。
  10. CA用自己的私钥给用户证书签名。
  11. CA把自己的用户证书和用户的私钥通过SSL通路传递给RA。
  12. 用户从RA下载证书。
  13. 用户安装证书。

2.双证书的签发

签名证书的签发

  • a) 用户填写信息注册(或者由RA的业务操作员注册用户)。
  • b) 用户本地ACTIVE控件调用IE中的加密机生成签名证书的密钥对。
  • c) 用户填写的信息和签名证书的公钥传递给RA。
  • d) RA把用户信息和公钥传递给CA。
  • e) CA根据用户信息和公钥制作成证书
  • f) CA用自己的私钥给用户证书签名。
  • g) CA把生成的用户证书传递给RA。
  • h) 用户从RA下载证书。
  • i)用户安装签名证书。

加密证书的签发

  • a) 用户把用户的签名证书传递到RA。
  • b) RA用户的签名证书传递到CA。
  • c) CA到KMC中取密钥对,(密钥对由加密机生成,生成的密钥对)。
  • d) CA把从签名证书中得到的用户信息和从KMC中取到的公钥制作成证书。
  • e) CA用自己的私钥给用户证书签名。
  • f) CA调用签名证书的公钥给加密证书和用户加密证书的私钥加密
  • g) CA把加密之后的加密证书和加密证书的私钥传递给RA。
  • h) 用户从RA加密之后的加密证书和加密证书的私钥。
  • i) 用户在本地调用签名证书的私钥解密加密证书和加密证书的私钥。
  • j) 用户安装加密证书。

二、具体实现

2.1 用户首先产生自己的密钥对,并将公共密钥及部分个人信息传送给CA(通过P10请求

 CertAndKeyGen gen = new CertAndKeyGen("RSA", "SHA1WithRSA");
  gen.generate(1024);//生成1024位密钥
 PKCS10CertificationRequestBuilder p10Builder = new JcaPKCS10CertificationRequestBuilder(
                     new X500Principal("CN = " + name), gen.getPublicKey());// CN和公钥 
  JcaContentSignerBuilder csBuilder = new JcaContentSignerBuilder("SHA256withRSA");// 签名算法
  ContentSigner signer = null;
  signer = csBuilder.build(gen.getPrivateKey());
  PKCS10CertificationRequest csr = p10Builder.build(signer);// PKCS10的请求
  return csr;//返回PKCS10的请求

2.2 CA接受请求并生成证书

CertificateFactory certFactory = CertificateFactory.getInstance("X.509");
X509Certificate cacert = (X509Certificate) certFactory.generateCertificate(new  FileInputStream(certPath));
//一大堆参数 ,填充到生成器里
AlgorithmIdentifier sigAlgId = new       DefaultSignatureAlgorithmIdentifierFinder().find("SHA1withRSA");
AlgorithmIdentifier digAlgId = new DefaultDigestAlgorithmIdentifierFinder().find(sigAlgId);
org.bouncycastle.asn1.x500.X500Name issuer = new org.bouncycastle.asn1.x500.X500Name(
                                          cacert.getSubjectX500Principal().getName());        BigInteger serial = new BigInteger(32, new SecureRandom());
  Date from = new Date();
  Date to = new Date(System.currentTimeMillis() + (365 * 80 * 86400000L));

  X509v3CertificateBuilder certgen = new X509v3CertificateBuilder(issuer, serial, from, to,                                                                    csr.getSubject(),
csr.getSubjectPublicKeyInfo())
Key privateKey = productPrivateKey();
// CA端进行签名, 才有具有法律效力
ContentSigner signer = new BcRSAContentSignerBuilder(sigAlgId, digAlgId)
               .build(PrivateKeyFactory.createKey(privateKey.getEncoded()));
// 生成BC结构的证书
 Security.addProvider(new BouncyCastleProvider());
X509Certificate resultBc = new JcaX509CertificateConverter().setProvider("BC").getCertificate(certgen.build(signer));
  return resultBc;//返回证书

三、P10请求详解

  • 定义:证书请求文件,类似于CSR文件。
  • p10证书一般是一个base64文件,实际上他不是一张真正的证书应该是一段可以向CA申请证书的P10请求,该请求一般是通过硬件生成密钥对后,将私钥单独存放,但是将公钥放入p10中,CA受到该p10请求后,可以校验,并根据p10中的信息制作一张没有私钥的公钥证书。

CSR:证书签发请求(Certificate Signing Request),

  • CSR也叫做认证申请,是一个发送到CA的请求认证信息。 有两种格式,应用最广泛的是由PKCS#10定义的,另一个用的少的是由SPKAC定义的,主要应用于网景浏览器。

  • 在PKCS#10定义中,CSR有两种编码格式:二进制(ASN.1或DER (Distinguished Encoding Rules))和文本格式(the text or PEM (Privacy Enhanced Mail)formatted CSR is the binary CSR after it has been Base-64 encoded to create a text version of the CSR.)

  • CSR文件生成步骤如下:

    • 根据Version、Distinguished Name、Public Key、Attributes生成请求证书;
    • 用Private Key加密证书请求信息;
    • 根据请求信息、签名算法和签名生成CSR文件;
  • CSR文件包含的信息描述如下

         CertificationRequest ::= SEQUENCE {
         certificationRequestInfo CertificationRequestInfo,//证书信息
         signatureAlgorithm AlgorithmIdentifier{{ SignatureAlgorithms }},//签名算法
         signature          BIT STRING //签名
       }//另外还可能有可选的字段,如postal address和Email address,这两个字段可以应用于证书的撤销。  
    

注意:私钥不包含在CSR文件中,但是应用于数字签名

签名分两步

  • 将certificateRequestInfo 进行DER编码,产生八位字节字符串;

  • 将步骤一的结果用请求者的私钥在指定的签名算法下,产生签名;

  • 请求信息定义如下

    CertificationRequestInfo ::= SEQUENCE {       
       version       INTEGER { v1(0) } (v1,...),
        subject       Name, //证书主体的专有名称
        subjectPKInfo SubjectPublicKeyInfo{{ PKInfoAlgorithms }},
        attributes    [0] Attributes{{ CRIAttributes }}
    }
    
  • subjectPublicKeyInfo 包含被认证的公钥

  • attributes 关于认证主提其他信息属性集合

     SubjectPublicKeyInfo { ALGORITHM : IOSet} ::= SEQUENCE {
        algorithm        AlgorithmIdentifier {{IOSet}},
        subjectPublicKey BIT STRING
    }
    
    PKInfoAlgorithms ALGORITHM ::= {
        ...  -- add any locally defined algorithms here -- }
    
    Attributes { ATTRIBUTE:IOSet } ::= SET OF Attribute{{ IOSet }}
    
    CRIAttributes  ATTRIBUTE  ::= {
        ... -- add any locally defined attributes here -- }
    
    Attribute { ATTRIBUTE:IOSet } ::= SEQUENCE {
        type   ATTRIBUTE.&id({IOSet}),
        values SET SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{@type})
    }
    
  • 等价写法

    CertificationRequest ::= SIGNED { EncodedCertificationRequestInfo }
        (CONSTRAINED BY { -- Verify or sign encoded
         -- CertificationRequestInfo -- })
    
      EncodedCertificationRequestInfo ::=
          TYPE-IDENTIFIER.&Type(CertificationRequestInfo)
    
     SIGNED { ToBeSigned } ::= SEQUENCE {
        toBeSigned ToBeSigned,
        algorithm  AlgorithmIdentifier { {SignatureAlgorithms} },
         signature  BIT STRING
      }
    

相关文章

  • PKCS#10 以及证书颁发过程

    一、证书颁发 1.单证书的签发 用户填写信息注册(或者由RA的业务操作员注册用户)。 用户信息传递到RA。 RA审...

  • openssl shell辅助工具

    最近折腾自签名证书,研究了下生成根证书、服务端证书、颁发客户证书; 以及证书吊销;结合nginx实现自签名双向认证...

  • HTTPS

    https介绍 作用: 见证书颁发机构: 购买: 证书类型: 域名类型: 工作中选择域名过程: 注意域名证书的到期...

  • 2018-03-02 certtool的用法

    备注:certtool的用法 生成PKCS#10格式的证书请求:--generate-request --outf...

  • 0

    ①RSA2048 p10[iOS]通过openssl库生成pkcs#10证书iOS开发——openssl生成CSR...

  • 问题记录:因为此网站发送了 Google Chrome 无法处理

    删除证书,然后重启即可。 点击地址栏小锁,找到证书颁发者。 删除证书颁发机构

  • Buypass Go SSL 免费SSL证书提供商

    Buypass AS是ETSI认证的证书颁发机构(CA) ,根据PKI标准颁发SSL证书、企业证书和个人 ID 。...

  • ios开发-真机调试与ipa打包

    过程: 1.在启动台中找到钥匙串访问并启动。 2.选择钥匙串访问->证书助理->从证书颁发机构请求证书... 3....

  • CA证书颁发以及SSH的用法

    1、创建私有CA并进行证书申请。 2、总结ssh常用参数、用法 SSH(全称 Secure Shell)是一种加密...

  • 讲清楚charles抓包原理

    基础概念 1. CA CA是证书颁发机构,不是随便什么人都能成为证书颁发机构,关键是你颁发的证书要别人认可。别人认...

网友评论

    本文标题:PKCS#10 以及证书颁发过程

    本文链接:https://www.haomeiwen.com/subject/nodbkftx.html