Sample code for 30+ languages & platforms
PHP ActiveX

RSA Encrypt with SHA-256 hash function and SHA-256 mask function

See more RSA Examples

How can this Javascript be duplicated using Chilkat?
function a(e, t) {
                var r = s.pki.publicKeyFromPem(e)
                  , n = r.encrypt(t, "RSA-OAEP", {
                    md: s.md.sha256.create(),
                    mgf1: {
                        md: s.md.sha1.create()
                    }
                });
                return s.util.encode64(n)
            }

Note: The OAEP padding uses random bytes in the padding, and therefore each time encryption happens, even using the same data and key, the result will be different -- but still valid. One should not expect to get the same output.

Chilkat PHP ActiveX Downloads

PHP ActiveX
<?php

$success = 0;

// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

$pubkey = new COM("Chilkat.PublicKey");

$sbPem = new COM("Chilkat.StringBuilder");
$bCrlf = 1;
$sbPem->AppendLine('-----BEGIN PUBLIC KEY-----',$bCrlf);
$sbPem->AppendLine('MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA33TqqLR3eeUmDtHS89qF',$bCrlf);
$sbPem->AppendLine('3p4MP7Wfqt2Zjj3lZjLjjCGDvwr9cJNlNDiuKboODgUiT4ZdPWbOiMAfDcDzlOxA',$bCrlf);
$sbPem->AppendLine('04DDnEFGAf+kDQiNSe2ZtqC7bnIc8+KSG/qOGQIVaay4Ucr6ovDkykO5Hxn7OU7s',$bCrlf);
$sbPem->AppendLine('Jp9TP9H0JH8zMQA6YzijYH9LsupTerrY3U6zyihVEDXXOv08vBHk50BMFJbE9iwF',$bCrlf);
$sbPem->AppendLine('wnxCsU5+UZUZYw87Uu0n4LPFS9BT8tUIvAfnRXIEWCha3KbFWmdZQZlyrFw0buUE',$bCrlf);
$sbPem->AppendLine('f0YN3/Q0auBkdbDR/ES2PbgKTJdkjc/rEeM0TxvOUf7HuUNOhrtAVEN1D5uuxE1W',$bCrlf);
$sbPem->AppendLine('SwIDAQAB',$bCrlf);
$sbPem->AppendLine('-----END PUBLIC KEY-----',$bCrlf);

// Load the public key object from the PEM. 
$success = $pubkey->LoadFromString($sbPem->getAsString());
if ($success == 0) {
    print $pubkey->LastErrorText . "\n";
    exit;
}

$originalData = 'This is the original data to be SHA-256 hashed and RSA encrypted.';

// First we SHA-256 hash the original data.
$crypt = new COM("Chilkat.Crypt2");
$crypt->HashAlgorithm = 'SHA-256';

$hashBytes = $crypt->HashString($originalData);

// Now to RSA encrypt using OAEP padding with SHA-256 for the mask function.
$rsa = new COM("Chilkat.Rsa");
$rsa->PkcsPadding = 0;
$rsa->OaepHash = 'SHA256';
$rsa->UsePublicKey($pubkey);
$rsa->EncodingMode = 'base64';

// Note: The OAEP padding uses random bytes in the padding, and therefore each time encryption happens,
// even using the same data and key, the result will be different --  but still valid.  One should not expect
// to get the same output.
$bUsePrivateKey = 0;
$encryptedStr = $rsa->encryptBytesENC($hashBytes,$bUsePrivateKey);
if ($rsa->LastMethodSuccess == 0) {
    print $rsa->LastErrorText . "\n";
    exit;
}

print 'Base64 RSA encrypted output: ' . $encryptedStr . "\n";

?>