downloads | documentation | faq | getting help | mailing lists | licenses | wiki | reporting bugs | php.net sites | conferences | my php.net

search for in the

openssl_pkcs7_decrypt> <openssl_pkcs12_export
[edit] Last updated: Fri, 17 May 2013

view this page in

openssl_pkcs12_read

(PHP 5 >= 5.2.2)

openssl_pkcs12_readSpeichert ein PKCS#12 Zertifikat in einem Array

Beschreibung

bool openssl_pkcs12_read ( mixed $PKCS12 , array &$certs , string $pass )

openssl_pkcs12_read() speichert das im Parameter PKCS12 übergebene PKCS#12 Zertifikat als Array im Parameter certs.

Parameter-Liste

PKCS12

certs

Enthält im Erfolgsfall die Zertifikatsdaten als Array.

pass

Passwort zum Entschlüsseln der PKCS#12-Datei.

Rückgabewerte

Gibt bei Erfolg TRUE zurück. Im Fehlerfall wird FALSE zurückgegeben.



add a note add a note User Contributed Notes openssl_pkcs12_read - [2 notes]
up
1
bromatom at directbox dot com
4 years ago
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
  (
  )
)
up
-3
mmacia at gmail dot com
5 years ago
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';
}
?>

 
show source | credits | stats | sitemap | contact | advertising | mirror sites