openssl_pkcs7_sign
(PHP 4 >= 4.0.6, PHP 5)
openssl_pkcs7_sign — Signe un message S/MIME
Description
$infilename
   , string $outfilename
   , mixed $signcert
   , mixed $privkey
   , array $headers
   [, int $flags = PKCS7_DETACHED
   [, string $extracerts
  ]] )
    openssl_pkcs7_sign() prend le contenu du fichier
   infilename et le signe en utilisant le
   certificat et la clé privée contenus dans les arguments
   signcert et privkey.
  
Liste de paramètres
- 
     infilename
- 
      
- 
     outfilename
- 
      
- 
     signcert
- 
      
- 
     privkey
- 
      
- 
     headers
- 
      headersest un tableau d'en-têtes qui seront ajoutés aux données chiffrées (voir la fonction openssl_pkcs7_encrypt() pour plus de détails sur le format du paramètre).
- 
     flags
- 
      flagssert à modifier le message final. Voyez les constantes PKCS7.
- 
     extracerts
- 
      extracertsspécifie le nom du fichier contenant un ensemble de certificats supplémentaires à inclure dans la signature, qui pourront aider le destinataire à vérifier les données que vous utilisez.
Valeurs de retour
   Cette fonction retourne TRUE en cas de
succès ou FALSE si une erreur survient.
  
Exemples
Exemple #1 Exemple avec openssl_pkcs7_sign()
<?php // le message que vous voulez signer, afin que le destinataire soit sûr qu'il // vient bien de vous $data = <<<EOD Tu peux dépenser jusqu'à 10000 euros en note de frais. Ton boss EOD; // sauvez le message dans un fichier $fp = fopen("msg.txt", "w"); fwrite($fp, $data); fclose($fp); // encrypt it if (openssl_pkcs7_sign("msg.txt", "signed.txt", "mycert.pem", array("file://mycert.pem", "mypassphrase"), array("To" => "joes@example.com", // syntaxe à clé "From: HQ <ceo@example.com>", // syntaxe indexée "Subject" => "Eyes only") )) { // message signée - envoyez-le ! exec(ini_get("sendmail_path") . " < signed.txt"); } ?>
