(PHP 5 >= 5.2.2)
openssl_pkcs12_read — Speichert ein PKCS#12 Zertifikat in einem Array
openssl_pkcs12_read() speichert das im Parameter PKCS12 übergebene PKCS#12 Zertifikat als Array im Parameter certs.
Enthält im Erfolgsfall die Zertifikatsdaten als Array.
Passwort zum Entschlüsseln der PKCS#12-Datei.
Gibt bei Erfolg TRUE zurück. Im Fehlerfall wird FALSE zurückgegeben.
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
(
)
)
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';
}
?>