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
(Node.js) Get Public Key from CSRDemonstrates how to get the public key from a CSR.
var os = require('os'); if (os.platform() == 'win32') { var chilkat = require('@chilkat/ck-node23-win64'); } else if (os.platform() == 'linux') { if (os.arch() == 'arm') { var chilkat = require('@chilkat/ck-node23-linux-arm'); } else if (os.arch() == 'arm64') { var chilkat = require('@chilkat/ck-node23-linux-arm64'); } else { var chilkat = require('@chilkat/ck-node23-linux-x64'); } } else if (os.platform() == 'darwin') { var chilkat = require('@chilkat/ck-node23-mac-universal'); } 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-2025 Chilkat Software, Inc. All Rights Reserved.