![]() |
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
(AutoIt) RSA Signature/Verify with .key and .cerSee more RSA ExamplesDemonstrates how to use a .key file (private key) and digital certificate (.cer, public key) to create and verify an RSA signature.Note: This example requires Chilkat v11.0.0 or greater.
Local $bSuccess = False ; This example assumes the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. $oPrivKey = ObjCreate("Chilkat.PrivateKey") ; Load the private key from an RSA .key file: $bSuccess = $oPrivKey.LoadPemFile("privateKey.key") If ($bSuccess = False) Then ConsoleWrite($oPrivKey.LastErrorText & @CRLF) Exit EndIf $oRsa = ObjCreate("Chilkat.Rsa") ; Import the private key into the RSA component: $bSuccess = $oRsa.UsePrivateKey($oPrivKey) If ($bSuccess = False) Then ConsoleWrite($oRsa.LastErrorText & @CRLF) Exit EndIf ; Create the signature as a hex string: $oRsa.EncodingMode = "hex" Local $strData = "This is the string to be signed." ; Sign the string using the sha256 hash algorithm. ; Other valid choices are "md2", "sha1", "sha384", ; "sha512", and "md5". Local $sHexSig = $oRsa.SignStringENC($strData,"sha256") ConsoleWrite($sHexSig & @CRLF) ; Load a digital certificate from a .cer file: $oCert = ObjCreate("Chilkat.Cert") $bSuccess = $oCert.LoadFromFile("myCert.cer") If ($bSuccess = False) Then ConsoleWrite($oCert.LastErrorText & @CRLF) Exit EndIf $oPubKey = ObjCreate("Chilkat.PublicKey") $oCert.GetPublicKey($oPubKey) ; Now verify using a new instance of the RSA object: $oRsa2 = ObjCreate("Chilkat.Rsa") ; Import the public key into the RSA object: $bSuccess = $oRsa2.UsePublicKey($oPubKey) If ($bSuccess = False) Then ConsoleWrite($oRsa2.LastErrorText & @CRLF) Exit EndIf ; The signature is a hex string, so make sure the EncodingMode is correct: $oRsa2.EncodingMode = "hex" ; Verify the signature: $bSuccess = $oRsa2.VerifyStringENC($strData,"sha256",$sHexSig) If ($bSuccess = False) Then ConsoleWrite($oRsa2.LastErrorText & @CRLF) Exit EndIf ConsoleWrite("Success." & @CRLF) |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.