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
(Visual FoxPro) 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).
LOCAL loPkey LOCAL lnSuccess LOCAL lcPkeyXml LOCAL loRsa LOCAL lcStrData LOCAL lcHexSig LOCAL loCert LOCAL loPubKey LOCAL lcPubKeyXml LOCAL loRsa2 * This example assumes the Chilkat API to have been previously unlocked. * See Global Unlock Sample for sample code. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.PrivateKey') loPkey = CreateObject('Chilkat.PrivateKey') * Load the private key from an RSA PEM file: lnSuccess = loPkey.LoadPkcs8EncryptedFile("raul_privateKey.key","a0123456789") * Get the private key in XML format: lcPkeyXml = loPkey.GetXml() * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Rsa') loRsa = CreateObject('Chilkat.Rsa') * Import the private key into the RSA component: lnSuccess = loRsa.ImportPrivateKey(lcPkeyXml) IF (lnSuccess <> 1) THEN ? loRsa.LastErrorText RELEASE loPkey RELEASE loRsa CANCEL ENDIF * This example will sign a string, and receive the signature * in a hex-encoded string. Therefore, set the encoding mode * to "hex": loRsa.EncodingMode = "hex" lcStrData = "This is the string to be signed." * Sign the string using the sha-1 hash algorithm. * Other valid choices are "md2" and "md5". lcHexSig = loRsa.SignStringENC(lcStrData,"sha-1") ? lcHexSig * Now verify with the public key. * This example shows how to use the public key from * a digital certificate (.cer file) * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Cert') loCert = CreateObject('Chilkat.Cert') lnSuccess = loCert.LoadFromFile("raul_publicKey.cer") IF (lnSuccess <> 1) THEN ? loCert.LastErrorText RELEASE loPkey RELEASE loRsa RELEASE loCert CANCEL ENDIF loPubKey = loCert.ExportPublicKey() * Get the private key in XML format: lcPubKeyXml = loPubKey.GetXml() * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Rsa') loRsa2 = CreateObject('Chilkat.Rsa') lnSuccess = loRsa2.ImportPublicKey(lcPubKeyXml) IF (lnSuccess <> 1) THEN ? loRsa2.LastErrorText RELEASE loPkey RELEASE loRsa RELEASE loCert RELEASE loRsa2 CANCEL ENDIF * Verify the signature against the original data: loRsa2.EncodingMode = "hex" lnSuccess = loRsa2.VerifyStringENC(lcStrData,"sha-1",lcHexSig) IF (lnSuccess <> 1) THEN ? loRsa2.LastErrorText RELEASE loPkey RELEASE loRsa RELEASE loCert RELEASE loRsa2 CANCEL ENDIF ? "Signature verified!" * Verify with incorrect data: lnSuccess = loRsa2.VerifyStringENC("something else","sha-1",lcHexSig) IF (lnSuccess <> 1) THEN ? "Signature not verified! (which was expected in this case)" ELSE ? "Hmmm... that's not right..." ENDIF RELEASE loPubKey RELEASE loPkey RELEASE loRsa RELEASE loCert RELEASE loRsa2 |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.