Sample code for 30+ languages & platforms
PHP ActiveX

Verfies an RSA Signature

See more Apple Keychain Examples

Verifies an RSA signature against the original data.

Chilkat PHP ActiveX Downloads

PHP ActiveX
<?php

$success = 0;

// The following data was signed by the following example:
// RSA Sign using a Private Key on a USB Token or Smartcard
$bd = new COM("Chilkat.BinData");

for ($i = 0; $i <= 100; $i++) {
    $bd->AppendEncoded('000102030405060708090A0B0C0D0E0F','hex');
}

// Load the signature
$bdSig = new COM("Chilkat.BinData");
$success = $bdSig->LoadFile('rsaSignatures/test1.sig');
if ($success == 0) {
    print 'Failed to load the RSA signature' . "\n";
    exit;
}

// Get the public key to be used for signature verification.
$pubKey = new COM("Chilkat.PublicKey");
$success = $pubKey->LoadFromFile('rsaKeys/chilkat-rsa-2048.pem');
if ($success == 0) {
    print $pubKey->LastErrorText . "\n";
    exit;
}

$rsa = new COM("Chilkat.Rsa");
$success = $rsa->UsePublicKey($pubKey);
if ($success == 0) {
    print $rsa->LastErrorText . "\n";
    exit;
}

// Verify the hash of the data against the signature.
// We pass in the original data.  Internally, the hash is generated
// and used to validate the signature.
// Validating the RSA signature means two things:  
// (1) the original data is exactly what was signed, and 
// (2) it was signed by the owner of the RSA private key.
$success = $rsa->VerifyBd($bd,'sha256',$bdSig);

if ($success == 0) {
    print $rsa->LastErrorText . "\n";
    print 'Signature invalid.' . "\n";
}
else {
    print 'Signature valid.' . "\n";
}


?>