php - 如何在 PHP 中创建数字证书并导出到 .p12 文件?

标签 php openssl x509 digital-certificate pkcs#12

如何在 PHP 中创建数字证书并导出到 .p12 文件?

我希望 .p12 文件包含私钥。并且还想检查 key 对是否已经发布(登录数据库)。

我找到了一个名为“openssl_pkcs12_export_to_file”的函数,但不知道从哪里开始。看来我首先需要一个 X509 证书和一个私钥。

最佳答案

<?php
error_reporting(-1);

function dump($Var) {
  echo "<hr/><pre>";
  var_dump($Var);
  echo "</pre><hr/>";
}

function check_errors() {
  echo "<hr/><pre>";
  $Count = 0;
  while (($e=openssl_error_string())!==false) {
    echo $e."<br>";
    $Count++;
  }
  if ($Count==0)
    echo "No error";
  echo "</pre><hr/>";
}

$Configs = array(
  "config" => "e:/progetti/php/openssl/openssl.cfg",
  "digest_alg" => "sha1",
  "x509_extensions" => "v3_ca",
  "req_extensions" => "v3_req",
  "private_key_bits" => 1024,
  "private_key_type" => OPENSSL_KEYTYPE_RSA,
  "encrypt_key" => true,
  "encrypt_key_cipher" => OPENSSL_CIPHER_3DES 
);
$Info = array(
  "countryName" => "VN",
  "stateOrProvinceName" => "Hanoi",
  "localityName" => "Long Bien",
  "organizationName" => "Test Company",
  "organizationalUnitName" => "Test Department",
  "commonName" => "Tester",
  "emailAddress" => "test@gmail.com"
);

$Private_Key = null;
$Unsigned_Cert = openssl_csr_new($Info,$Private_Key,$Configs);
check_errors();
dump($Private_Key);
dump($Unsigned_Cert);

$Signed_Cert = openssl_csr_sign($Unsigned_Cert,null,$Private_Key,365,$Configs);
check_errors();
dump($Signed_Cert);

openssl_pkcs12_export_to_file($Signed_Cert,"test.p12",$Private_Key,"123456");
check_errors();

关于php - 如何在 PHP 中创建数字证书并导出到 .p12 文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8341999/

相关文章:

php - 用 PHP 发送电子邮件 - 接收空白电子邮件

ssl - IDEAL 的 OpenSSL 证书

x509 - X.509 标准属性集顺序

php - MySQL表中的日期格式

php - 如何在 symfony2 中将 json 转换为 php 对象?

php - 如何制作像 url 这样的个人资料?

c++ - 调用 fork() 后 SSL_accept 挂起

iis - IIS 的个人 CA 签名证书给出 "This Certificate is not valid for the selected purpose"错误

c - X.509v3 ASN.1至C数据结构

ssl - 拉取存储库时出现 X509 解析错误, 'negative serial number'