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
(Node.js) Get Public Key from CSRDemonstrates how to get the public key from a CSR.
var os = require('os'); if (os.platform() == 'win32') { if (os.arch() == 'ia32') { var chilkat = require('@chilkat/ck-node21-win-ia32'); } else { var chilkat = require('@chilkat/ck-node21-win64'); } } else if (os.platform() == 'linux') { if (os.arch() == 'arm') { var chilkat = require('@chilkat/ck-node21-arm'); } else if (os.arch() == 'x86') { var chilkat = require('@chilkat/ck-node21-linux32'); } else { var chilkat = require('@chilkat/ck-node21-linux64'); } } else if (os.platform() == 'darwin') { if (os.arch() == 'arm64') { var chilkat = require('@chilkat/ck-node21-mac-m1'); } else { var chilkat = require('@chilkat/ck-node21-macosx'); } } function chilkatExample() { // This requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. var pem = new chilkat.Pem(); // No password is required. Pass an empty password string.. var noPassword = ""; var success = pem.LoadPemFile("qa_data/csr/csr2.pem",noPassword); if (success !== true) { console.log(pem.LastErrorText); return; } var strBase64 = pem.GetEncodedItem("csr","","base64",0); var asn = new chilkat.Asn(); success = asn.LoadEncoded(strBase64,"base64"); if (success !== true) { console.log(asn.LastErrorText); return; } // Convert the ASN.1 to XML. var xml = new chilkat.Xml(); success = xml.LoadXml(asn.AsnToXml()); console.log(xml.GetXml()); console.log("----"); var strModulusHex = xml.GetChildContent("bits"); console.log("strModulusHex = " + strModulusHex); console.log("----"); // We need the modulus as base64. var bd = new chilkat.BinData(); bd.AppendEncoded(strModulusHex,"hex"); var modulus64 = bd.GetEncoded("base64"); console.log("modulus64 = " + modulus64); console.log("----"); // Build the XML for the public key. var xmlPubKey = new chilkat.Xml(); xmlPubKey.Tag = "RSAPublicKey"; xmlPubKey.UpdateChildContent("Modulus",modulus64); // The RSA exponent will always be decimal 65537 (base64 = AQAB) xmlPubKey.UpdateChildContent("Exponent","AQAB"); console.log("RSA public key as XML:"); console.log(xmlPubKey.GetXml()); console.log("----"); // Load the XML into a Chilkat public key object. var pubkey = new chilkat.PublicKey(); success = pubkey.LoadFromString(xmlPubKey.GetXml()); if (success !== true) { console.log(pubkey.LastErrorText); return; } // Show the public key as PEM. var preferPkcs1 = true; console.log(pubkey.GetPem(preferPkcs1)); } chilkatExample(); |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.