To extract the contents of a PKCS12 file you can use file_get_contents as well:
<?
$certs = array();
$pkcs12 = file_get_contents( "pkcs12file.pem" );
// No password
openssl_pkcs12_read( $pkcs12, $certs, "" );
print_r( $certs );
?>
Output is:
Array
(
[cert] => --- BEGIN CERTIFICATE ---
//snipsnip//
--- END CERTIFICATE ---
[pkey] => --- BEGIN RSA PRIVATE KEY ---
//snipsnip//
[extracerts] = Array
(
)
)
openssl_pkcs12_read
(PHP 5 >= 5.2.2)
openssl_pkcs12_read — Parse a PKCS#12 Certificate Store into an array
Descrizione
openssl_pkcs12_read() parses the PKCS#12 certificate store supplied by PKCS12 into a array named certs .
Elenco dei parametri
- PKCS12
-
- certs
-
On success, this will hold the Certificate Store Data.
- pass
-
Encryption password for unlocking the PKCS#12 file.
Valori restituiti
Restituisce TRUE in caso di successo, FALSE in caso di fallimento.
openssl_pkcs12_read
bromatom at directbox dot com
01-Sep-2008 09:18
01-Sep-2008 09:18
mmacia at gmail dot com
26-Dec-2007 02:13
26-Dec-2007 02:13
The correct way to read a PKCS#12 file is:
<?php
$p12cert = array();
$file = '/home/mmacia/mycert.p12';
$fd = fopen($file, 'r');
$p12buf = fread($fd, filesize($file));
fclose($fd);
if ( openssl_pkcs12_read($p12buf, $p12cert, 'passphrase') )
{
echo 'Works!';
print_r($p12cert);
}
else
{
echo 'Fail';
}
?>
