Encrypt using private key, decrypt using public key.
Use this for posting signed messages: Anyone with access to
your public key can read it, but they can't create one with
your signature.
<?php
echo "Source: $source";
$fp=fopen("/path/to/private.key","r");
$priv_key=fread($fp,8192);
fclose($fp);
// $passphrase is required if your key is encoded (suggested)
$res = openssl_get_privatekey($priv_key,$passphrase);
/*
* NOTE: Here you use the returned resource value
*/
openssl_private_encrypt($source,$crypttext,$res);
echo "String crypted: $crypttext";
$fp=fopen ("/path/to/certificate.crt","r");
$pub_key=fread($fp,8192);
fclose($fp);
openssl_get_publickey($pub_key);
/*
* NOTE: Here you use the $pub_key value (converted, I guess)
*/
openssl_public_decrypt($crypttext,$newsource,$pub_key);
echo "String decrypt : $newsource";
?>
openssl_private_encrypt
(PHP 4 >= 4.0.6, PHP 5)
openssl_private_encrypt — Chiffre des données avec une clé privée
Description
bool openssl_private_encrypt
( string $data
, string &$crypted
, mixed $key
[, int $padding= OPENSSL_PKCS1_PADDING
] )
openssl_private_encrypt() chiffre les données data avec la clé privée key et stocke le résultat dans crypted . Les données chiffrées peuvent être déchiffrées avec la fonction openssl_public_decrypt().
Cette fonction peut être utilisée pour signer les données (ou leurs chiffrements) pour prouver qu'elles n'ont pas été écrites par une autre personne.
Liste de paramètres
- data
-
- crypted
-
- key
-
- padding
-
Le paramètre padding est fixé par défaut à OPENSSL_PKCS1_PADDING mais peut prendre la valeur OPENSSL_NO_PADDING.
Valeurs de retour
Cette fonction retourne TRUE en cas de succès, FALSE en cas d'échec.
Voir aussi
- openssl_public_encrypt() - Chiffre des données avec une clé publique
- openssl_public_decrypt() - Déchiffre des données avec une clé publique
openssl_private_encrypt
wfredkNOSPAM at L5DevelopmentNOSPAM dot com
08-Mar-2002 11:50
08-Mar-2002 11:50
billnet at tiscalinet dot it
28-Jan-2002 06:47
28-Jan-2002 06:47
<?php
$fp=fopen ("/path/to/key.pem","r");
$priv_key=fread ($fp,8192);
fclose($fp);
openssl_get_privatekey ($priv_key);
openssl_private_encrypt($source,$finaltext,$priv_key);
echo "String crypted: $finaltext";
?>
CIAO !
