Sample code for 30+ languages & platforms
Delphi ActiveX

RSA Sign Binary Data and Verify (Recover the Original Data)

See more RSA Examples

Demonstrates how to RSA sign binary data and then verify/recover the original data.

Note: This example uses methods introduced in Chilkat v9.5.0.77.

Chilkat Delphi ActiveX Downloads

Delphi ActiveX
uses
    Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
    Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Integer;
privKey: TPrivateKey;
rsa: TChilkatRsa;
originalData: WideString;
bd: TChilkatBinData;
pubKey: TPublicKey;
rsa2: TChilkatRsa;
bVerified: Integer;

begin
success := 0;

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

// Load an RSA private key for signing.
privKey := TPrivateKey.Create(Self);
success := privKey.LoadEncryptedPemFile('qa_data/pem/rsa_passwd.pem','passwd');
if (success = 0) then
  begin
    Memo1.Lines.Add(privKey.LastErrorText);
    Exit;
  end;

rsa := TChilkatRsa.Create(Self);
rsa.UsePrivateKey(privKey.ControlInterface);

// We have some binary data (in hex) to sign
originalData := '0102030405060708090A';
bd := TChilkatBinData.Create(Self);
bd.AppendEncoded(originalData,'hex');

// If successful, the contents of bd are replaced with the RSA signature.
success := rsa.SignRawBd(bd.ControlInterface);
if (success = 0) then
  begin
    Memo1.Lines.Add(rsa.LastErrorText);
    Exit;
  end;

// Show the RSA signature in base64
Memo1.Lines.Add(bd.GetEncoded('base64'));

// ------------------------------------------
// Get the public key from the private key
pubKey := TPublicKey.Create(Self);
privKey.ToPublicKey(pubKey.ControlInterface);

// Verify the signature and extract the original data.
rsa2 := TChilkatRsa.Create(Self);
rsa2.UsePublicKey(pubKey.ControlInterface);

bVerified := rsa2.VerifyRawBd(bd.ControlInterface);
Memo1.Lines.Add('signature verified: ' + IntToStr(Ord(bVerified)));

// Show the original data:
Memo1.Lines.Add('original data: ' + bd.GetEncoded('hex'));
end;