|  | 
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
| (PowerShell) JWE using ECDH-ES+A256KWSee more JSON Web Encryption (JWE) ExamplesCreate a JWE with the following public/private key pair:
{
    "kty": "EC",
    "d": "jZCffzVqJjryBH4EoaN0oD-TyLXrW2XHoDdIuPZnk8c",
    "use": "enc",
    "crv": "P-256",
    "kid": "evEK2thJMsWxBYRivXI8ykUf6n6zizLiLCGH3s58wKs",
    "x": "LOakgGvxWBsWbCPLY6Vq6OuBktIqG8POXFXe7ngQ2oM",
    "y": "voJvS6I-Mc4qqmEA_G2hLQqBck3a3vqaJbmzY7YPUD4",
    "alg": "ECDH-ES+A256KW"
}
Also shows how to decrypt. 
 Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll" # This requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. # Create the following JSON: # { # "kty": "EC", # "d": "jZCffzVqJjryBH4EoaN0oD-TyLXrW2XHoDdIuPZnk8c", # "use": "enc", # "crv": "P-256", # "kid": "evEK2thJMsWxBYRivXI8ykUf6n6zizLiLCGH3s58wKs", # "x": "LOakgGvxWBsWbCPLY6Vq6OuBktIqG8POXFXe7ngQ2oM", # "y": "voJvS6I-Mc4qqmEA_G2hLQqBck3a3vqaJbmzY7YPUD4", # "alg": "ECDH-ES+A256KW" # } $json = New-Object Chilkat.JsonObject $json.UpdateString("kty","EC") $json.UpdateString("d","jZCffzVqJjryBH4EoaN0oD-TyLXrW2XHoDdIuPZnk8c") $json.UpdateString("use","enc") $json.UpdateString("crv","P-256") $json.UpdateString("kid","evEK2thJMsWxBYRivXI8ykUf6n6zizLiLCGH3s58wKs") $json.UpdateString("x","LOakgGvxWBsWbCPLY6Vq6OuBktIqG8POXFXe7ngQ2oM") $json.UpdateString("y","voJvS6I-Mc4qqmEA_G2hLQqBck3a3vqaJbmzY7YPUD4") $json.UpdateString("alg","ECDH-ES+A256KW") $pubkey = New-Object Chilkat.PublicKey $success = $pubkey.LoadFromString($json.Emit()) if ($success -eq $false) { $($pubkey.LastErrorText) exit } # Build our protected header: # { # "alg": "ECDH-ES+A256KW", # "enc": "A256GCM", # "exp": 1621957030, # "cty": "NJWT", # "epk": { # "kty": "EC", # "x": "QLpJ_LpFx-6yJhsb4OvHwU1khLnviiOwYOvmf5clK7w" # "y": "AJh7pJ3zZKDJkm8rbeG69GBooTosXJgSsvNFH0i3Vxnu" # "crv": "BP-256" # } # } # Use jwt only for getting the current date/time + 3600 seconds. $jwt = New-Object Chilkat.Jwt $jweProtHdr = New-Object Chilkat.JsonObject $jweProtHdr.UpdateString("alg","ECDH-ES+A256KW") $jweProtHdr.UpdateString("enc","A256GCM") $jweProtHdr.UpdateInt("exp",$jwt.GenNumericDate(3600)) $jweProtHdr.UpdateString("cty","NJWT") $jweProtHdr.UpdateString("epk.kty","EC") $jweProtHdr.UpdateString("epk.x","LOakgGvxWBsWbCPLY6Vq6OuBktIqG8POXFXe7ngQ2oM") $jweProtHdr.UpdateString("epk.y","voJvS6I-Mc4qqmEA_G2hLQqBck3a3vqaJbmzY7YPUD4") $jweProtHdr.UpdateString("epk.crv","P-256") $jwe = New-Object Chilkat.Jwe $jwe.SetProtectedHeader($jweProtHdr) $jwe.SetPublicKey(0,$pubkey) $plainText = "This is the text to be encrypted." $strJwe = $jwe.Encrypt($plainText,"utf-8") if ($jwe.LastMethodSuccess -ne $true) { $($jwe.LastErrorText) exit } $($strJwe) # Let's decrypt... $privkey = New-Object Chilkat.PrivateKey $success = $privkey.LoadJwk($json.Emit()) if ($success -eq $false) { $($privkey.LastErrorText) exit } $jwe2 = New-Object Chilkat.Jwe $success = $jwe2.LoadJwe($strJwe) if ($success -eq $false) { $($jwe2.LastErrorText) exit } $jwe2.SetPrivateKey(0,$privkey) # Decrypt. $decryptedText = $jwe2.Decrypt(0,"utf-8") if ($jwe2.LastMethodSuccess -ne $true) { $($jwe2.LastErrorText) exit } $($decryptedText) | ||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.