Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Delphi ActiveX) RSA Sign Using Private Key from .pfx/.p12 to Base64 SignatureSee more RSA ExamplesDemonstrates how to RSA sign something using a private key loaded from a .pfx/.p12. The RSA signature is returned in Base64 encoded format.
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 rsa: TChilkatRsa; pfx: TChilkatPfx; success: Integer; privKey: IPrivateKey; strData: WideString; base64Sig: WideString; begin // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. rsa := TChilkatRsa.Create(Self); // Load the .pfx/.p12 pfx := TChilkatPfx.Create(Self); success := pfx.LoadPfxFile('qa_data/pfx/myKey.p12','myPassword'); if (success <> 1) then begin Memo1.Lines.Add(pfx.LastErrorText); Exit; end; // Get the default private key. privKey := pfx.GetPrivateKey(0); if (pfx.LastMethodSuccess <> 1) then begin Memo1.Lines.Add(pfx.LastErrorText); Exit; end; // Import the private key into the RSA component: success := rsa.ImportPrivateKeyObj(privKey); if (success <> 1) then begin Memo1.Lines.Add(rsa.LastErrorText); Exit; end; // Get the signature in base64 rsa.EncodingMode := 'base64'; strData := 'This is the string to be signed.'; // Sign the string using the sha256 hash algorithm. // Other valid choices are "sha384", "sha512", "sha-1", "md2" and "md5". base64Sig := rsa.SignStringENC(strData,'sha256'); Memo1.Lines.Add(base64Sig); Memo1.Lines.Add('Success!'); end; |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.