openssl_pkcs7_sign

(PHP 4 >= 4.0.6, PHP 5)

openssl_pkcs7_signSigne un message S/MIME

Description

bool openssl_pkcs7_sign ( string $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

headers est 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

flags sert à modifier le message final. Voyez les constantes PKCS7.

extracerts

extracerts spé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()

  1. <?php
  2. // le message que vous voulez signer, afin que le destinataire soit sûr qu'il
  3. // vient bien de vous
  4. $data = <<<EOD
  5.  
  6. Tu peux dépenser jusqu'à 10000 euros en note de frais.
  7.  
  8. Ton boss
  9. EOD;
  10. // sauvez le message dans un fichier
  11. $fp = fopen("msg.txt", "w");
  12. fwrite($fp, $data);
  13. fclose($fp);
  14. // encrypt it
  15. if (openssl_pkcs7_sign("msg.txt", "signed.txt", "mycert.pem",
  16. array("file://mycert.pem", "mypassphrase"),
  17. array("To" => "joes@example.com", // syntaxe à clé
  18. "From: HQ <ceo@example.com>", // syntaxe indexée
  19. "Subject" => "Eyes only")
  20. )) {
  21. // message signée - envoyez-le !
  22. exec(ini_get("sendmail_path") . " < signed.txt");
  23. }
  24. ?>

LoadingChargement en cours