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
(PowerShell) Create JWT using a Brainpool EC KeySee more JSON Web Token (JWT) ExamplesDemonstrates how to create a JWT using an EC private key. This is for JOSE headers having an "alg" member with any of the following values:
This example also demonstrates how to include time constraints:
Add-Type -Path "C:\chilkat\ChilkatDotNet47-9.5.0-x64\ChilkatDotNet47.dll" # Demonstrates how to create a JWT using a brainpool EC private key. # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. $privKey = New-Object Chilkat.PrivateKey # Load a brainpool EC key. $success = $privKey.LoadPemFile("c:/qa_data/pem/ec_brainpool_privKey.pem") if ($success -ne $true) { $($privKey.LastErrorText) exit } # You can examine the curve name of the key you just loaded by getting the private in XML format: # <ECCKeyValue curve="CURVE_NAME">...</ECCKeyValue> $($privKey.GetXml()) $jwt = New-Object Chilkat.Jwt # Build the JOSE header $jose = New-Object Chilkat.JsonObject # Use the brainpool curve name matching the private key you just loaded. # Use "BP256R1", or "BP384R1", etc. $success = $jose.AppendString("alg","BP256R1") $success = $jose.AppendString("typ","JWT") # Now build the JWT claims (also known as the payload) $claims = New-Object Chilkat.JsonObject $success = $claims.AppendString("iss","http://example.org") $success = $claims.AppendString("sub","John") $success = $claims.AppendString("aud","http://example.com") # Set the timestamp of when the JWT was created to now. $curDateTime = $jwt.GenNumericDate(0) $success = $claims.AddIntAt(-1,"iat",$curDateTime) # Set the "not process before" timestamp to now. $success = $claims.AddIntAt(-1,"nbf",$curDateTime) # Set the timestamp defining an expiration time (end time) for the token # to be now + 1 hour (3600 seconds) $success = $claims.AddIntAt(-1,"exp",$curDateTime + 3600) # Produce the smallest possible JWT: $jwt.AutoCompact = $true # Create the JWT token. This is where the ECC signature is created. $token = $jwt.CreateJwtPk($jose.Emit(),$claims.Emit(),$privKey) $($token) |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.