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) Generate ECDSA Key and Get Details as XMLDemonstrates how to generate an ECC key and gets the parts as XML.
; This requires the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. $oEcc = ObjCreate("Chilkat_9_5_0.Ecc") ; Generate a random ECC private key on the secp256k1 curve. ; Chilkat also supports other curves, such as secp384r1, secp521r1, and secp256r1. ; Create a Fortuna PRNG and seed it with system entropy. ; This will be our source of random data for generating the ECC private key. $oFortuna = ObjCreate("Chilkat_9_5_0.Prng") Local $sEntropy = $oFortuna.GetEntropy(32,"base64") Local $bSuccess = $oFortuna.AddEntropy($sEntropy,"base64") Local $oPrivKey = $oEcc.GenEccKey("secp256k1",$oFortuna) If ($oEcc.LastMethodSuccess <> True) Then ConsoleWrite($oEcc.LastErrorText & @CRLF) Exit EndIf ; An EC private key has this ASN.1 ; ECPrivateKey ::= SEQUENCE { ; version INTEGER { ecPrivkeyVer1(1) } (ecPrivkeyVer1), ; privateKey OCTET STRING, ; parameters [0] ECParameters {{ NamedCurve }} OPTIONAL, ; publicKey [1] BIT STRING OPTIONAL (This is the ANSI X9.63 public key format.) $oAsn = ObjCreate("Chilkat_9_5_0.Asn") $bSuccess = $oAsn.LoadEncoded($oPrivKey.GetPkcs1ENC("base64"),"base64") If ($bSuccess <> True) Then ConsoleWrite($oAsn.LastErrorText & @CRLF) Exit EndIf $oXml = ObjCreate("Chilkat_9_5_0.Xml") $oXml.LoadXml($oAsn.AsnToXml()) ConsoleWrite($oXml.GetXml() & @CRLF) ; The XML looks like this: ; <?xml version="1.0" encoding="utf-8" ?> ; <sequence> ; <int>01</int> ; <octets>JgJvBG+3wletkJab8iXAkpz0O8/AgWZSpkYVcB7SpnU=</octets> ; <contextSpecific tag="0" constructed="1"> ; <oid>1.3.132.0.10</oid> ; </contextSpecific> ; </sequence> ; The 32-byte private key is in the octets.. ; Get it as hex. $oCrypt = ObjCreate("Chilkat_9_5_0.Crypt2") Local $sPrivKeyHex = $oCrypt.ReEncode($oXml.GetChildContent("octets"),"base64","hex") ConsoleWrite("EC private key as hex = " & $sPrivKeyHex & @CRLF) |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.