Sample code for 30+ languages & platforms
Delphi DLL

RSASSA-PSS Algorithm with SHA256 Hashing

See more RSA Examples

RSA encrypt a SHA256 hash with OAEP padding.

Chilkat Delphi DLL Downloads

Delphi DLL
uses
    Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
    Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, PrivateKey, Rsa;

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
privkey: HCkPrivateKey;
rsa: HCkRsa;
sigStr: PWideChar;

begin
success := False;

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

privkey := CkPrivateKey_Create();

// Load the private key object from a PEM file.
// (To load from a PEM string, call LoadPem instead.)
success := CkPrivateKey_LoadPemFile(privkey,'somePath/myPrivateKey.pem');
if (success = False) then
  begin
    Memo1.Lines.Add(CkPrivateKey__lastErrorText(privkey));
    Exit;
  end;

rsa := CkRsa_Create();
// Use RSA-PSS by setting PkcsPadding = False
CkRsa_putPkcsPadding(rsa,False);
// Use SHA256
CkRsa_putOaepHash(rsa,'SHA-256');

CkRsa_UsePrivateKey(rsa,privkey);

// Generate a base64 signature.
CkRsa_putEncodingMode(rsa,'base64');

sigStr := CkRsa__signStringENC(rsa,'String to be signed','SHA-256');
if (CkRsa_getLastMethodSuccess(rsa) = False) then
  begin
    Memo1.Lines.Add(CkRsa__lastErrorText(rsa));
    Exit;
  end;

Memo1.Lines.Add('Signature: ' + sigStr);

CkPrivateKey_Dispose(privkey);
CkRsa_Dispose(rsa);

end;