(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL phar >= 1.1.0)
Phar::setSignatureAlgorithm — Fixe et applique l'algorithme de signature d'un phar
$algo
, ?string $privateKey
= null
): voidNote:
Cette méthode nécessite que la variable de configuration INI
phar.readonly
soit définie à0
pour fonctionner avec les objets Phar. Sinon, une exception PharException sera lançée.
Fixe et applique l'algorithme de signature d'un phar. L'algorithme de signature doit être
Phar::MD5
, Phar::SHA1
, Phar::SHA256
,
Phar::SHA512
, ou Phar::OPENSSL
.
Notez que toutes les archives phar exécutables ont
une signature créée automatiquement, SHA1
par défaut.
Les archives de données basées sur tar ou sur zip (créées avec la classe
PharData) doivent avoir leur signature créée et
assignée explicitement via Phar::setSignatureAlgorithm().
algo
Un des algorithmes Phar::MD5
,
Phar::SHA1
, Phar::SHA256
,
Phar::SHA512
, ou Phar::OPENSSL
privateKey
Le contenu d'une clé privée OpenSSL, telle qu'extraite d'un certificat ou d'un fichier de clé OpenSSL :
<?php
$private = openssl_get_privatekey(file_get_contents('private.pem'));
$pkey = '';
openssl_pkey_export($private, $pkey);
$p->setSignatureAlgorithm(Phar::OPENSSL, $pkey);
?>
Aucune valeur n'est retournée.
Lève une exception UnexpectedValueException pour de nombreuses erreurs et une exception PharException si des problèmes surviennent durant l'écriture des changements sur le disque.
Version | Description |
---|---|
8.0.0 |
privateKey est désormais nullable.
|