使用PHP将DER格式的.key文件加载到PEM

时间:2015-09-15 21:55:03

标签: php openssl pem der

我有一个代码可以进行转换但需要使用本机PHP函数来完成,因为它没有激活支持运行exec:

exec("openssl pkcs8 -inform DER -in 'archivo.key' -out 'archivo.key.pem' -passin pass:'lacontrasena'");

有人可以帮我翻译成本机PHP函数吗?它可以是openssl或库。

//更新

这是我使用der2pem函数的代码:

function der2pem($der_data) {
   $pem = chunk_split(base64_encode($der_data), 64, "\n");
   $pem = "-----BEGIN PRIVATE KEY-----\n".$pem."-----END PRIVATE KEY-----\n";
   return $pem;
}
$keyfile = 'myFileDER.key';
$keyFileContent = file_get_contents($keyfile);
$pemContent = der2pem($keyFileContent);
file_put_contents('llavetemp.pem', $pemContent);

$private_key1 = openssl_pkey_get_private($pemContent);

var_dump($private_key1);

var_dump返回布尔值false

2 个答案:

答案 0 :(得分:2)

您可以轻松使用uri2x的答案以及第一个Google搜索结果中的一些信息。 PEM只是二进制DER文件的base64编码形式。 添加了一些元数据,您可以使用它完成所有操作。

所以,如果您将功能(由uri2x发布!)修改为以下内容:

$private_key=file_get_contents('archivo.key');
file_put_contents('archivo.key.pem',der2pem($private_key,'PRIVATE KEY');

你现在可以叫它:

//certificates
$private_key=file_get_contents('certificate');
echo der2pem($private_key,'CERTIFICATE');//here, certificate isn't even required because it's the default
//GPG/PGP Public Keys
$pgp_public_key=file_get_contents('pgp_public_key');
echo der2pem($private_key,'PGP PUBLIC KEY BLOCK');
//CSR
$certificate_signing_request=file_get_contents('csr');
echo der2pem($private_key,'CERTIFICATE REQUEST');

你几乎可以改变所有需要在密码问题中转移的东西:

user_1
user_2
user_3
...
user_9999999

......和many其他人!

答案 1 :(得分:0)

请参阅php.net上的dan's评论:

  

使用以下代码将DER转换为PEM,将PEM转换为DER。

<?php
$pem_data = file_get_contents($cert_path.$pem_file);
$pem2der = pem2der($pem_data);

$der_data = file_get_contents($cert_path.$der_file);
$der2pem = der2pem($der_data);

function pem2der($pem_data) {
   $begin = "CERTIFICATE-----";
   $end   = "-----END";
   $pem_data = substr($pem_data, strpos($pem_data, $begin)+strlen($begin));   
   $pem_data = substr($pem_data, 0, strpos($pem_data, $end));
   $der = base64_decode($pem_data);
   return $der;
}

function der2pem($der_data) {
   $pem = chunk_split(base64_encode($der_data), 64, "\n");
   $pem = "-----BEGIN CERTIFICATE-----\n".$pem."-----END CERTIFICATE-----\n";
   return $pem;
}