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 DLL) RSA Sign with PKCS8 Encrypted KeyDemonstrates how to load a private key from an encrypted PKCS8 file and create an RSA digital signature (and then verify it).
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, PublicKey, PrivateKey, Rsa, Cert; ... procedure TForm1.Button1Click(Sender: TObject); var pkey: HCkPrivateKey; success: Boolean; pkeyXml: PWideChar; rsa: HCkRsa; strData: PWideChar; hexSig: PWideChar; cert: HCkCert; pubKey: HCkPublicKey; pubKeyXml: PWideChar; rsa2: HCkRsa; begin // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. pkey := CkPrivateKey_Create(); // Load the private key from an RSA PEM file: success := CkPrivateKey_LoadPkcs8EncryptedFile(pkey,'raul_privateKey.key','a0123456789'); // Get the private key in XML format: pkeyXml := CkPrivateKey__getXml(pkey); rsa := CkRsa_Create(); // Import the private key into the RSA component: success := CkRsa_ImportPrivateKey(rsa,pkeyXml); if (success <> True) then begin Memo1.Lines.Add(CkRsa__lastErrorText(rsa)); Exit; end; // This example will sign a string, and receive the signature // in a hex-encoded string. Therefore, set the encoding mode // to "hex": CkRsa_putEncodingMode(rsa,'hex'); strData := 'This is the string to be signed.'; // Sign the string using the sha-1 hash algorithm. // Other valid choices are "md2" and "md5". hexSig := CkRsa__signStringENC(rsa,strData,'sha-1'); Memo1.Lines.Add(hexSig); // Now verify with the public key. // This example shows how to use the public key from // a digital certificate (.cer file) cert := CkCert_Create(); success := CkCert_LoadFromFile(cert,'raul_publicKey.cer'); if (success <> True) then begin Memo1.Lines.Add(CkCert__lastErrorText(cert)); Exit; end; pubKey := CkCert_ExportPublicKey(cert); // Get the private key in XML format: pubKeyXml := CkPublicKey__getXml(pubKey); rsa2 := CkRsa_Create(); success := CkRsa_ImportPublicKey(rsa2,pubKeyXml); if (success <> True) then begin Memo1.Lines.Add(CkRsa__lastErrorText(rsa2)); Exit; end; // Verify the signature against the original data: CkRsa_putEncodingMode(rsa2,'hex'); success := CkRsa_VerifyStringENC(rsa2,strData,'sha-1',hexSig); if (success <> True) then begin Memo1.Lines.Add(CkRsa__lastErrorText(rsa2)); Exit; end; Memo1.Lines.Add('Signature verified!'); // Verify with incorrect data: success := CkRsa_VerifyStringENC(rsa2,'something else','sha-1',hexSig); if (success <> True) then begin Memo1.Lines.Add('Signature not verified! (which was expected in this case)'); end else begin Memo1.Lines.Add('Hmmm... that''s not right...'); end; CkPublicKey_Dispose(pubKey); CkPrivateKey_Dispose(pkey); CkRsa_Dispose(rsa); CkCert_Dispose(cert); CkRsa_Dispose(rsa2); end; |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.