Delphi DLL
Delphi DLL
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 DLL Downloads
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, BinData, PrivateKey, Rsa, PublicKey;
...
procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
privKey: HCkPrivateKey;
rsa: HCkRsa;
originalData: PWideChar;
bd: HCkBinData;
pubKey: HCkPublicKey;
rsa2: HCkRsa;
bVerified: Boolean;
begin
success := False;
// 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 := CkPrivateKey_Create();
success := CkPrivateKey_LoadEncryptedPemFile(privKey,'qa_data/pem/rsa_passwd.pem','passwd');
if (success = False) then
begin
Memo1.Lines.Add(CkPrivateKey__lastErrorText(privKey));
Exit;
end;
rsa := CkRsa_Create();
CkRsa_UsePrivateKey(rsa,privKey);
// We have some binary data (in hex) to sign
originalData := '0102030405060708090A';
bd := CkBinData_Create();
CkBinData_AppendEncoded(bd,originalData,'hex');
// If successful, the contents of bd are replaced with the RSA signature.
success := CkRsa_SignRawBd(rsa,bd);
if (success = False) then
begin
Memo1.Lines.Add(CkRsa__lastErrorText(rsa));
Exit;
end;
// Show the RSA signature in base64
Memo1.Lines.Add(CkBinData__getEncoded(bd,'base64'));
// ------------------------------------------
// Get the public key from the private key
pubKey := CkPublicKey_Create();
CkPrivateKey_ToPublicKey(privKey,pubKey);
// Verify the signature and extract the original data.
rsa2 := CkRsa_Create();
CkRsa_UsePublicKey(rsa2,pubKey);
bVerified := CkRsa_VerifyRawBd(rsa2,bd);
Memo1.Lines.Add('signature verified: ' + IntToStr(Ord(bVerified)));
// Show the original data:
Memo1.Lines.Add('original data: ' + CkBinData__getEncoded(bd,'hex'));
CkPrivateKey_Dispose(privKey);
CkRsa_Dispose(rsa);
CkBinData_Dispose(bd);
CkPublicKey_Dispose(pubKey);
CkRsa_Dispose(rsa2);
end;