Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Delphi DLL) RSA Signature SHA256withRSA, iso-8859-1, base64See more RSA ExamplesRSA sign the iso-8859-1 byte representation of a string with SHA256withRSA, and return the signature in the base64 encoding.
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 privKey: HCkPrivateKey; success: Boolean; rsa: HCkRsa; originalData: PWideChar; sigBase64: PWideChar; begin // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // This example will duplicate the following Java code: // // Signature sign = Signature.getInstance("SHA256withRSA"); // sign.initSign(privateKey); // sign.update(original.getBytes(Charset.forName("ISO-8859-1"))); // // ... // byte[] resultado = sign.sign(); // sello = encodeByteArrayToBase64(resultado); // // Load an RSA private key for signing. // You can load any format file. This example loads a .pem, but you can provide path to any type of file holding a private key. privKey := CkPrivateKey_Create(); success := CkPrivateKey_LoadAnyFormatFile(privKey,'qa_data/pem/rsa_passwd.pem','passwd'); if (success <> True) then begin Memo1.Lines.Add(CkPrivateKey__lastErrorText(privKey)); Exit; end; rsa := CkRsa_Create(); CkRsa_ImportPrivateKeyObj(rsa,privKey); originalData := 'This is the string to be hashed an RSA signed.'; // Indicate that we want the iso-8859-1 byte representation of the string to be signed CkRsa_putCharset(rsa,'iso-8859-1'); // We want the RSA signature in base64 format CkRsa_putEncodingMode(rsa,'base64'); sigBase64 := CkRsa__signStringENC(rsa,originalData,'sha256'); Memo1.Lines.Add(sigBase64); CkPrivateKey_Dispose(privKey); CkRsa_Dispose(rsa); end; |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.