php RSA 生成证书,从证书导出密钥,公钥

generate.php
  
    $dn = array(  

        "countryName" => 'XX', //所在国家名称  

        "stateOrProvinceName" => 'State', //所在省份名称  

        "localityName" => 'SomewhereCity', //所在城市名称  

        "organizationName" => 'MySelf',   //注册人姓名  

        "organizationalUnitName" => 'Whatever', //组织名称  

        "commonName" => 'mySelf', //公共名称  

        "emailAddress" => 'user@domain.com' //邮箱  

);  

    $privkeypass = '111111'; //私钥密码  

    $numberofdays = 365;     //有效时长  

    $cerpath = "./test.cer"; //生成证书路径  

    $pfxpath = "./test.pfx"; //密钥文件路径  

    

    //生成证书  

    $privkey = openssl_pkey_new(); 

    $csr = openssl_csr_new($dn, $privkey);  

    $sscert = openssl_csr_sign($csr, null, $privkey, $numberofdays);  

    openssl_x509_export_to_file($sscert, $cerpath); //导出证书到文件

    openssl_pkcs12_export_to_file($sscert, $pfxpath, $privkey, $privkeypass); //生成密钥文件  
crypt.php

 
   
         
    //私钥加密
      $cer_key =file_get_contents($pfxpath); //获取密钥内容
      openssl_pkcs12_read($cer_key, $certs, $privkeypass);
      openssl_sign($data, $signMsg, $certs['pkey'],OPENSSL_ALGO_SHA1);//注册生成加密信息
      $signMsg =base64_encode($signMsg); //base64转码加密信息
      echo$signMsg;
     
     
      //公钥解密
      $cer_key =file_get_contents($cerpath); //获取证书内容
      $unsignMsg=base64_decode($signMsg);//base64解码加密信息
      $cer =openssl_x509_read($cer_key); //读取公钥
      $res =openssl_verify($data, $unsignMsg, $cer); //验证
      echo $res;//输出验证结果,1:验证成功,0:验证失败

一个简单的加密解密类:

class RsaCrypt {
      constPRIVATE_KEY_FILE_PATH = './rsa_private_key.pem';
      constPUBLIC_KEY_FILE_PATH = './rsa_public_key.pem';

     
      publicstatic function encode($orignData) {
              //密钥文件的路径
              $privateKeyFilePath = self::PRIVATE_KEY_FILE_PATH;
              extension_loaded('openssl') or die('php需要openssl扩展支持');
              (file_exists($privateKeyFilePath)) or die('密钥的文件路径不正确');
              //生成Resource类型的密钥,如果密钥文件内容被破坏,openssl_pkey_get_private函数返回false
              $privateKey =openssl_pkey_get_private(file_get_contents($privateKeyFilePath));
         
              ($privateKey) or die('密钥不可用');
              //加密以后的数据,用于在网路上传输
              $encryptData = '';
              ///用私钥加密
              if (openssl_private_encrypt($orignData, $encryptData, $privateKey)){
                      return $encryptData;
              } else {
                      die('加密失败');
              }
      }
     
      publicstatic function decode($encryptData) {
              //公钥文件的路径
              $publicKeyFilePath = self::PUBLIC_KEY_FILE_PATH;
              extension_loaded('openssl') or die('php需要openssl扩展支持');
              (file_exists($publicKeyFilePath)) or die('公钥的文件路径不正确');
              //生成Resource类型的公钥,如果公钥文件内容被破坏,openssl_pkey_get_public函数返回false
              $publicKey =openssl_pkey_get_public(file_get_contents($publicKeyFilePath));
              ($publicKey) or die('公钥不可用');
              //解密以后的数据
              $decryptData = '';
              ///用公钥解密
              if (openssl_public_decrypt($encryptData, $decryptData, $publicKey)){
                      return $decryptData;
              } else {
                      die('解密失败');
              }
      }
}
特别说明:

x509,公钥证书,只有公钥。
p7,签名或加密。可以往里面塞x509,同时没有签名或加密内容。
p12,含有私钥,同时可以有公钥,有口令保护。
p7的作用就是电子信封。
X509是基本规范
P7和P12是两个实现规范,P7是数字信封,P12是带有私钥的证书规范。
x509是数字证书的规范,P7和P12是两种封装形式。比如说同样的电影,有的是avi格式,有的是mpg,大概就这个意思。

P7一般是把证书分成两个文件,一个公钥一个私钥,有PEM和DER两种编码方式。PEM比较多见,就是纯文本的,P7一般是分发公钥用,看到的就是一串可见字符串,扩展名经常是.crt,.cer,.key等。DER是二进制编码。
P12是把证书压成一个文件,.pfx。主要是考虑分发证书,私钥是要绝对保密的,不能随便以文本方式散播。所以P7格式不适合分发。.pfx中可以加密码保护,所以相对安全些。
在实践中要中,用户证书都是放在USBKey中分发,服务器证书经常还是以文件方式分发。服务器证书和用户证书,都是X509证书,就是里面的属性有区别。

X509 是证书规范
PKCS#7 是消息语法 (常用于数字签名与加密)
PKCS#12 个人消息交换与打包语法 (如.PFX .P12)打包成带公钥与私钥
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Java 中生成 PKCS1 格式的 RSA 密钥对可以使用 Java Cryptography Extension (JCE) 中的 `KeyPairGenerator` 类。这里是一个示例代码: ``` import java.security.KeyPair; import java.security.KeyPairGenerator; import java.security.NoSuchAlgorithmException; import java.security.PrivateKey; import java.security.PublicKey; public class GenerateRSAKeyPair { public static void main(String[] args) { try { // 获取 KeyPairGenerator 对象 KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA"); // 初始化 KeyPairGenerator 对象,设置密钥长度 keyPairGenerator.initialize(2048); // 生成密钥对 KeyPair keyPair = keyPairGenerator.generateKeyPair(); // 获取公钥和私钥 PublicKey publicKey = keyPair.getPublic(); PrivateKey privateKey = keyPair.getPrivate(); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } } } ``` 在上面的代码中,我们使用 `KeyPairGenerator.getInstance("RSA")` 方法获取了一个 `KeyPairGenerator` 对象,然后调用 `initialize` 方法设置密钥长度,最后调用 `generateKeyPair` 方法生成密钥对。生成密钥对包含一个公钥和一个私钥,分别可以使用 `keyPair.getPublic()` 和 `keyPair.getPrivate()` 方法获取。 请注意,上面的代码中使用的是 PKCS#1 格式的 RSA 密钥,如果你想使用其他格式的密钥,可以更改 `KeyPairGenerator.getInstance` 方法的参数。例如,如果你想生成 PKCS#8 格式的密钥,可以使用 `KeyPairGenerator.getInstance("RSA", "SunRsaSign") ### 回答2: 要使用Java生成PKCS1 RSA密钥对,我们可以使用Java的密钥库(KeyStore)和Java加密标准(Java Cryptography Architecture,JCA)提供的工具和类来完成。 首先,我们需要使用KeyPairGenerator类生成RSA密钥对。示例代码如下: ```java import java.security.KeyPair; import java.security.KeyPairGenerator; import java.security.NoSuchAlgorithmException; public class GenerateRSAKeys { public static void main(String[] args) { try { // 选择RSA算法 KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA"); // 设置密钥长度,一般为1024、2048 keyPairGenerator.initialize(2048); // 生成密钥对 KeyPair keyPair = keyPairGenerator.generateKeyPair(); System.out.println("Public Key: " + keyPair.getPublic()); System.out.println("Private Key: " + keyPair.getPrivate()); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } } } ``` 上述代码中,我们通过调用KeyPairGenerator.getInstance("RSA")选择了RSA算法,然后通过调用keyPairGenerator.initialize(2048)设置密钥长度为2048位,最后通过调用keyPairGenerator.generateKeyPair()生成RSA密钥对。 运行该代码,我们将在控制台上看到生成公钥和私钥。请注意,这里输出的密钥格式可能不是PKCS1格式,而是Java中的默认格式。如果需要将密钥以PKCS1格式存储或导出,可以使用相关的编码和转换方法进行处理。 希望以上信息对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值