zoukankan      html  css  js  c++  java
  • PFX文件提取公钥私钥

    jks是JAVA的keytools证书工具支持的证书私钥格式。
    pfx是微软支持的私钥格式。

    cer是证书的公钥。

    如果是你私人要备份证书的话记得一定要备份成jks或者pfx格式,否则恢复不了。

    简单来说,cer就是你们家邮箱的地址,你可以把这个地址给很多人让他们往里面发信。
    pfx或jks就是你家邮箱的钥匙,别人有了这个就可以冒充你去你家邮箱看信,你丢了这个也没法开邮箱了

    =====================
    =====================


    https://blog.csdn.net/problem2050/article/details/50528704
    PFX文件提取公钥私钥

    方法1:

    原版PFX证书

    openssl pkcs12 -in myssl.pfx -nodes -out server.pem

     提取私钥

    openssl rsa -in server.pem -out server.key

    提出公钥

    openssl x509 -in server.pem -out server.crt

    方法2:

    2.从pfx提取密钥信息,并转换为key格式(pfx使用pkcs12模式补足)

      (1)提取密钥对

           openssl pkcs12 -in 1.pfx -nocerts -nodes -out 1.key

           //如果pfx证书已加密,会提示输入密码。如果cer证书没有安装,则密码没法验证

      (2)从密钥对提取私钥

           openssl rsa -in  1.key -out 1_pri.key

      (3)从密钥对提取公钥

           openssl rsa -in 1.key -pubout -out 1_pub.key

      (4)因为RSA算法使用的是pkcs8模式补足,需要对提取的私钥进一步处理

           openssl pkcs8 -topk8 -inform PEM -in 1_pri.key -outform PEM -nocrypt

           复制窗口中生成的密钥,保存为1_pri_pkcs8.key

      (5)得到密钥对1_pri_pkcs8.key和1_pub.key


    pkcs8格式的私钥转换工具。它处理在PKCS#8格式中的私钥文件。它可以用多样的PKCS#5 (v1.5 and v2.0)和 PKCS#12算法来处理没有解密的PKCS#8 PrivateKeyInfo格式和EncryptedPrivateKeyInfo格式。
    用法:
    [cpp] view plaincopy
    openssl pkcs8 [-inform PEM|DER] [-outform PEM|DER] [-in filename] [-passin arg] [-out filename]
    [-passout arg] [-topk8] [-noiter] [-nocrypt] [-nooct] [-embed] [-nsdb] [-v2 alg] [-v1 alg] [-engine id]
    选项说明:
    -inform PEM|DER::输入文件格式,DER或者PEM格式。DER格式采用ASN1的DER标准格式。一般用的多的都是PEM格式,就是base64编码格式。
    -outform DER|PEM:输出文件格式,DER或者PEM格式。
    -in filename:输入的密钥文件,默认为标准输入。如果密钥被加密,会提示输入一个密钥口令。
    -passin arg:输入文件口令保护来源。
    -out filename:输出文件,默认为标准输出。如果任何加密操作已经执行,会提示输入一个密钥值。输出的文件名字不能和输入的文件名一样。
    -passout arg:输出文件口令保护来源。
    -topk8:通常的是输入一个pkcs8文件和传统的格式私钥文件将会被写出。设置了此选项后,位置转换过来:输入一个传统格式的私钥文件,输出一个PKCS#8格式的文件。
    -noiter:MAC保护计算次数为1。
    -nocrypt:PKCS#8密钥产生或输入一般用一个适当地密钥来加密PKCS#8 EncryptedPrivateKeyInfo结构。设置了此选项后,一个不加密的PrivateKeyInfo结构将会被输出。这个选项一直不加密私钥文件,在绝对必要的时候才能够使用。某些软件例如一些JAVA代码签名软件使用不加密的私钥文件。
    -nooct:这个选项产生的RSA私钥文件是一个坏的格式,一些软件将会使用。特别的是,私钥文件必须附上一个八位组字符串,但是一些软件仅仅包含本身的结构体没有使八位组字符串所环绕。不采用八位组表示私钥。
    -embed:这个选项产生的RSA私钥文件是一个坏的格式。在私钥结构体中采用嵌入式DSA参数格式。在这个表单中,八位组字符串包含了ASN1 SEQUENCE中的两种结构:一个SEQUENCE包含了密钥参数,一个ASN1 INTEGER包含私钥值。
    -nsdb:这个选项产生的RSA私钥文件是一个坏的格式并兼容了Netscape私钥文件数据库。采用NetscapeDB的DSA格式。
    -v2 alg:采用PKCS#5 v2.0,并指定加密算法,默认的是PKCS#8私钥文件被叫做B<pbeWithMD5AndDES-CBC>(该算法用56字节的DES加密但是在PKCS#5 v1.5中有更加强壮的加密算法)的加密算法用口令进行加密。用B<-v2>选项,PKCS#5 v2.0相关的算法将会被使用,可以是des3(168字节)和rc2(128字节),推荐des3。
    -v1 alg:采用PKCS#5 v1.5或pkcs12,并指定加密算法。可采用的算法见下面。
    -engine id:指定硬件引擎。
    注意:
    加密了的PEM编码PKCS#8文件表单用下面的头部和尾部:
    -----BEGIN ENCRYPTED PRIVATE KEY-----
    -----END ENCRYPTED PRIVATE KEY-----
    未加密的表单用:
    -----BEGIN PRIVATE KEY-----
    -----END PRIVATE KEY-----
    跟传统的SSLeay算法相比,用PKCS#5 v2.0系列的算法加密私钥,有更高的安全性以及迭代次数。于是附加的安全性是经过深思熟虑的。
    默认的加密算法仅仅是56字节的,是因为它是PKCS#8所支持的最好的方法。
    有一些软件使用PKCS#12基于密钥的加密算法来加密PKCS#8格式的私钥:它们会自动的处理但是没有选项来操作。
    在PKCS#8格式中,有可能的是输出DER编码格式的经过加密的私钥文件,是因为加密的详细说明包含在DER等级中,相反的是传统的格式包含在PEM邓丽中。
    PKCS#5 v1.5和 PKCS#12 算法:
    各种各样的算法可以被选项-v1所使用。包含PKCS#5 v1.5和 PKCS#12 算法。详细描述如下:
    B<PBE-MD2-DES PBE-MD5-DES>:这两个算法包含在PKCS#5 v1.5中。它们仅仅提供56字节的保护,加密算法用DES。
    B<PBE-SHA1-RC2-64 PBE-MD2-RC2-64 PBE-MD5-RC2-64 PBE-SHA1-DES>:它们在传统的PKCS#5 v1.5中没有被提到,但是它们用同样地密钥引出算法,被一些软件所支持。在PKCS#5 v2.0中所提到。它们使用64字节的RC2以及56字节的DES。
    B<PBE-SHA1-RC4-128 PBE-SHA1-RC4-40 PBE-SHA1-3DES PBE-SHA1-2DES PBE-SHA1-RC2-128 PBE-SHA1-RC2-40>:它们是PKCS#12基于密钥的加密算法,它们允许使用高强度的加密算法,例如3des或128位的RC2。
    实例:
    用3des算法将传统的私钥文件转换为PKCS#5 v2.0:
    [cpp] view plaincopy
    openssl pkcs8 -in key.pem -topk8 -v2 des3 -out enckey.pem 

    用PKCS#5 1.5兼容的DES算法将私钥文件转换为pkcs8文件:
    [html] view plaincopy
    openssl pkcs8 -in ocspserverkey.pem -topk8 -out ocspkcs8key.pem 

    用PKCS#12兼容的3DES算法将私钥文件转换为pkcs8文件:
    [html] view plaincopy
    openssl pkcs8 -in key.pem -topk8 -out enckey.pem -v1 PBE-SHA1-3DES 

    读取一个DER格式加密了的PKCS#8格式的私钥:
    [cpp] view plaincopy
    openssl pkcs8 -inform DER -nocrypt -in key.der -out key.pem 

    转换一个PKCS#8格式的私钥到传统的私钥:
    [cpp] view plaincopy
    openssl pkcs8 -in pk8.pem -out key.pem 

    pkcs8中的私钥以明文存放:
    [html] view plaincopy
    openssl pkcs8 -in ocspserverkey.pem -topk8 -nocrypt -out ocspkcs8key.pem 

    标准:
    PKCS#5 v2.0的测试向量的实现是以通告的形式用高强度的迭代次数算法3DES、DES和RC2来加密的。很多人要确认能够解密产生的私钥。
    PKCS#8格式的DSA私钥文件没有备注文件中的:在PKCS#11 v2.01中的11.9节被隐藏了的。OpenSSL的默认DSA PKCS#8私钥格式隐藏在这个标准中。
    BUGs:
    必须有一个选项打印使用的加密算法的其他详细细节,例如迭代次数。
    PKCS#8用3DES和PKCS#5 v2.0必须是默认的私钥文件:目前为了命令的兼容性。

    =====================
    =====================

    创建openssl pfx证书文件

    https://blog.csdn.net/lixiaowei16/article/details/72639817

    1、生成key

    输入genrsa -out openssl.key 1024生成openssl.key文件。

    openssl.key为key的名字随意起,1024为密钥长度

    2、生成cer证书

    接着输入req -new -x509 -key openssl.key -out openssl.cer -days 3650 -subj /CN=***.website

    openssl.key为之前生成的key的名字,openssl.cer为生成的证书名字,3650为证书过期天数,CN的参数***.website是的你主机名或者IP地址(这里一定要写对,不然以后访问的话,浏览器会提示有风险)。

    这样就生成了证书文件openssl.cer

    3、生成需要的PFX私钥文件

    输入pkcs12 -export -out openssl.pfx -inkey openssl.key -in openssl.cer

    会让你输入密码,使用私钥时候使用的(千万不能忘记)。
    这样就生成了私钥文件openssl.pfx。

    4、生成了crt证书

    由于手机需要crt证书,所以需要的话还要生成crt
    输入req -new -x509 -key openssl.key -out openssl.crt -days 3650

  • 相关阅读:
    Spring异步调用注解@Async的使用
    maven 打包前 Junit 测试
    windows 访问局域网共享文件
    IBM MQ 集成CXF 发送JMS 消息
    VO、DTO、DO、PO的概念、区别和用处
    myeclipse创建的项目发布不了文档
    js获取jsp上下文地址
    Maven编译时,出现找不到符号
    Cause: java.lang.ClassCastException: java.lang.String cannot be cast to org.apache.ibatis.mapping.MappedStatement
    使用IDEA从github中下载fastdfs-client-java
  • 原文地址:https://www.cnblogs.com/kungfupanda/p/9012168.html
Copyright © 2011-2022 走看看