PHP Extension
PHP Extension
RSA Encrypt Randomly Generated AES Key
See more RSA Examples
Demonstrates how to RSA encrypt a randomly generated AES key.Chilkat PHP Extension Downloads
<?php
include("chilkat.php");
$success = false;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// First generate a 256-bit AES key (32 bytes).
$prng = new CkPrng();
$bdAesKey = new CkBinData();
$success = $prng->GenRandomBd(32,$bdAesKey);
// Use a public key from a certificate for RSA encryption.
$cert = new CkCert();
$success = $cert->LoadFromFile('qa_data/pem/mf_public_rsa.pem');
if ($success == false) {
print $cert->lastErrorText() . "\n";
exit;
}
$pubKey = new CkPublicKey();
$cert->GetPublicKey($pubKey);
$rsa = new CkRsa();
$success = $rsa->UsePublicKey($pubKey);
if ($success == false) {
print $rsa->lastErrorText() . "\n";
exit;
}
// RSA encrypt our 32-byte AES key.
// The contents of bdAesKey are replaced with result of the RSA encryption.
$success = $rsa->EncryptBd($bdAesKey,false);
if ($success == false) {
print $rsa->lastErrorText() . "\n";
exit;
}
// Return the result as a base64 string
$encryptedAesKey = $bdAesKey->getEncoded('base64');
print 'encrypted AES key = ' . $encryptedAesKey . "\n";
?>