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
(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.
; 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: Local $bSuccess = $oPrivKey.LoadPemFile("privateKey.key") If ($bSuccess <> True) Then ConsoleWrite($oPrivKey.LastErrorText & @CRLF) Exit EndIf Local $sPrivKeyXml ; Get the private key in XML format: $sPrivKeyXml = $oPrivKey.GetXml() $oRsa = ObjCreate("Chilkat.Rsa") ; Import the private key into the RSA component: $bSuccess = $oRsa.ImportPrivateKey($sPrivKeyXml) If ($bSuccess <> True) 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 sha-1 hash algorithm. ; Other valid choices are "md2", "sha256", "sha384", ; "sha512", and "md5". Local $sHexSig = $oRsa.SignStringENC($strData,"sha-1") ConsoleWrite($sHexSig & @CRLF) ; Load a digital certificate from a .cer file: $oCert = ObjCreate("Chilkat.Cert") $bSuccess = $oCert.LoadFromFile("myCert.cer") If ($bSuccess <> True) Then ConsoleWrite($oCert.LastErrorText & @CRLF) Exit EndIf Local $oPubKey $oPubKey = $oCert.ExportPublicKey() ; Now verify using a separate instance of the RSA object: $oRsa2 = ObjCreate("Chilkat.Rsa") ; Import the public key into the RSA object: $bSuccess = $oRsa2.ImportPublicKey($oPubKey.GetXml()) If ($bSuccess <> True) 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,"sha-1",$sHexSig) If ($bSuccess <> True) Then ConsoleWrite($oRsa2.LastErrorText & @CRLF) Exit EndIf ConsoleWrite("Success." & @CRLF) |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.