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
(DataFlex) Generate an RSA Key and Get as Base64 DERDemonstrates how to generate a 2048-bit RSA key and return the public and private parts as unencrypted Base64 encoded DER.
Use ChilkatAx-win32.pkg Procedure Test Handle hoRsa Boolean iSuccess Variant vPubKey Handle hoPubKey Boolean iBChoosePkcs1 String sPubKeyBase64Der Variant vPrivKey Handle hoPrivKey String sPrivKeyPkcs1 String sPrivKeyPkcs8 String sTemp1 // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. Get Create (RefClass(cComChilkatRsa)) To hoRsa If (Not(IsComObjectCreated(hoRsa))) Begin Send CreateComObject of hoRsa End // Generate a 2048-bit key. Chilkat RSA supports Get ComGenerateKey Of hoRsa 2048 To iSuccess If (iSuccess <> True) Begin Get ComLastErrorText Of hoRsa To sTemp1 Showln sTemp1 Procedure_Return End // Get the public part of the key. Get ComExportPublicKeyObj Of hoRsa To vPubKey If (IsComObject(vPubKey)) Begin Get Create (RefClass(cComChilkatPublicKey)) To hoPubKey Set pvComObject Of hoPubKey To vPubKey End // There are two possible formats for representing the RSA public key // in ASN.1 (DER). The possible formats are PKCS1 and PKCS8. // We can get either by setting bChoosePkcs1 to True or False. Move True To iBChoosePkcs1 Get ComGetEncoded Of hoPubKey iBChoosePkcs1 "base64" To sPubKeyBase64Der Showln "Public Key Base64 DER:" Showln sPubKeyBase64Der Send Destroy of hoPubKey // Now get the private key as Base64 DER: // Get the private part of the key. // (Note: A public key is actually just a subset of the private key. // If you have the private key, you also have the public key. // Thus Chilkat provides a method to get the public key from the private key.) Get ComExportPrivateKeyObj Of hoRsa To vPrivKey If (IsComObject(vPrivKey)) Begin Get Create (RefClass(cComChilkatPrivateKey)) To hoPrivKey Set pvComObject Of hoPrivKey To vPrivKey End // Again, we can get PKCS1 or PKCS8, but with different methods: Get ComGetPkcs1ENC Of hoPrivKey "base64" To sPrivKeyPkcs1 Showln "Private Key PKCS1 Base64 DER:" Showln sPrivKeyPkcs1 Get ComGetPkcs8ENC Of hoPrivKey "base64" To sPrivKeyPkcs8 Showln "Private Key PKCS8 Base64 DER:" Showln sPrivKeyPkcs8 Send Destroy of hoPrivKey End_Procedure |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.