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
(PureBasic) JWE with DEFLATE CompressionDemonstrates how to DEFLATE ("zip") compress the JWE payload prior to encryption. Note: This example requires Chilkat v9.5.0.66 or greater.
IncludeFile "CkStringBuilder.pb" IncludeFile "CkJwe.pb" IncludeFile "CkJsonObject.pb" Procedure ChilkatExample() ; This requires the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. ; Note: This example requires Chilkat v9.5.0.66 or greater. success.i ; Create some plaintext to be encrypted. ; This example will demonstrate with and without DEFLATE (zip) compression. sbPlainText.i = CkStringBuilder::ckCreate() If sbPlainText.i = 0 Debug "Failed to create object." ProcedureReturn EndIf bCrLf.i = 1 line.s = "Live long and prosper." CkStringBuilder::ckAppendLine(sbPlainText,line,bCrLf) CkStringBuilder::ckAppendLine(sbPlainText,line,bCrLf) CkStringBuilder::ckAppendLine(sbPlainText,line,bCrLf) CkStringBuilder::ckAppendLine(sbPlainText,line,bCrLf) ; The text to be encrypted: Debug CkStringBuilder::ckGetAsString(sbPlainText) jwe.i = CkJwe::ckCreate() If jwe.i = 0 Debug "Failed to create object." ProcedureReturn EndIf ; Build the JWE Protected Header: {"alg":"A128KW","enc":"A128CBC-HS256","zip":"DEF"} ; The "zip":"DEF" parameter indicates that the plaintext payload should ; be compressed prior to encryption. jweProtHdr.i = CkJsonObject::ckCreate() If jweProtHdr.i = 0 Debug "Failed to create object." ProcedureReturn EndIf CkJsonObject::ckAppendString(jweProtHdr,"alg","A128KW") CkJsonObject::ckAppendString(jweProtHdr,"enc","A128CBC-HS256") CkJsonObject::ckAppendString(jweProtHdr,"zip","DEF") CkJwe::ckSetProtectedHeader(jwe,jweProtHdr) ; Set the AES key wrap key: aesWrappingKey.s = "GawgguFyGrWKav7AX4VKUg" CkJwe::ckSetWrappingKey(jwe,0,aesWrappingKey,"base64url") ; Encrypt and return the JWE in sbJweCompressed: sbJweCompressed.i = CkStringBuilder::ckCreate() If sbJweCompressed.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success = CkJwe::ckEncryptSb(jwe,sbPlainText,"utf-8",sbJweCompressed) If success <> 1 Debug CkJwe::ckLastErrorText(jwe) CkStringBuilder::ckDispose(sbPlainText) CkJwe::ckDispose(jwe) CkJsonObject::ckDispose(jweProtHdr) CkStringBuilder::ckDispose(sbJweCompressed) ProcedureReturn EndIf ; Show the compressed JWE: Debug CkStringBuilder::ckGetAsString(sbJweCompressed) Debug "size of compressed JWE: " + Str(CkStringBuilder::ckLength(sbJweCompressed)) ; Now create a JWE without compression. CkJsonObject::ckDelete(jweProtHdr,"zip") ; Make sure to update the shared protected header: CkJwe::ckSetProtectedHeader(jwe,jweProtHdr) sbJweUncompressed.i = CkStringBuilder::ckCreate() If sbJweUncompressed.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success = CkJwe::ckEncryptSb(jwe,sbPlainText,"utf-8",sbJweUncompressed) If success <> 1 Debug CkJwe::ckLastErrorText(jwe) CkStringBuilder::ckDispose(sbPlainText) CkJwe::ckDispose(jwe) CkJsonObject::ckDispose(jweProtHdr) CkStringBuilder::ckDispose(sbJweCompressed) CkStringBuilder::ckDispose(sbJweUncompressed) ProcedureReturn EndIf ; Show the uncompressed JWE: Debug CkStringBuilder::ckGetAsString(sbJweUncompressed) Debug "size of uncompressed JWE: " + Str(CkStringBuilder::ckLength(sbJweUncompressed)) ; Decrypting is the same whether compression is used or not. ; The "zip" header in the JWE indicates that the payload should be ; automatically decompressed (inflated) after decrypting. jwe2.i = CkJwe::ckCreate() If jwe2.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success = CkJwe::ckLoadJweSb(jwe2,sbJweCompressed) If success <> 1 Debug CkJwe::ckLastErrorText(jwe2) CkStringBuilder::ckDispose(sbPlainText) CkJwe::ckDispose(jwe) CkJsonObject::ckDispose(jweProtHdr) CkStringBuilder::ckDispose(sbJweCompressed) CkStringBuilder::ckDispose(sbJweUncompressed) CkJwe::ckDispose(jwe2) ProcedureReturn EndIf ; Set the AES wrap key. CkJwe::ckSetWrappingKey(jwe2,0,aesWrappingKey,"base64url") ; Decrypt (also automatically decompresses). sbOriginalText.i = CkStringBuilder::ckCreate() If sbOriginalText.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success = CkJwe::ckDecryptSb(jwe2,0,"utf-8",sbOriginalText) If success <> 1 Debug CkJwe::ckLastErrorText(jwe2) CkStringBuilder::ckDispose(sbPlainText) CkJwe::ckDispose(jwe) CkJsonObject::ckDispose(jweProtHdr) CkStringBuilder::ckDispose(sbJweCompressed) CkStringBuilder::ckDispose(sbJweUncompressed) CkJwe::ckDispose(jwe2) CkStringBuilder::ckDispose(sbOriginalText) ProcedureReturn EndIf Debug "original text from compressed JWE: " Debug CkStringBuilder::ckGetAsString(sbOriginalText) ; ----------------------------------------------------------- ; Do the same with the uncompressed JWE success = CkJwe::ckLoadJweSb(jwe2,sbJweUncompressed) If success <> 1 Debug CkJwe::ckLastErrorText(jwe2) CkStringBuilder::ckDispose(sbPlainText) CkJwe::ckDispose(jwe) CkJsonObject::ckDispose(jweProtHdr) CkStringBuilder::ckDispose(sbJweCompressed) CkStringBuilder::ckDispose(sbJweUncompressed) CkJwe::ckDispose(jwe2) CkStringBuilder::ckDispose(sbOriginalText) ProcedureReturn EndIf ; Set the AES wrap key. CkJwe::ckSetWrappingKey(jwe2,0,aesWrappingKey,"base64url") ; Decrypt. CkStringBuilder::ckClear(sbOriginalText) success = CkJwe::ckDecryptSb(jwe2,0,"utf-8",sbOriginalText) If success <> 1 Debug CkJwe::ckLastErrorText(jwe2) CkStringBuilder::ckDispose(sbPlainText) CkJwe::ckDispose(jwe) CkJsonObject::ckDispose(jweProtHdr) CkStringBuilder::ckDispose(sbJweCompressed) CkStringBuilder::ckDispose(sbJweUncompressed) CkJwe::ckDispose(jwe2) CkStringBuilder::ckDispose(sbOriginalText) ProcedureReturn EndIf Debug "original text from uncompressed JWE: " Debug CkStringBuilder::ckGetAsString(sbOriginalText) ; ------------------------------------------------ ; The output of this example is: ; (Note: Your output data will be different because the content encryption key is randomly generated.) ; eyJhbGciOiJBMTI4S1ciLCJlbmMiOiJBMTI4Q0JDLUhTMjU2IiwiemlwIjoiREVGIn0.xuW-pEAIdEUFnk10m8ocursvktO8Of9ByCCAt6LgKkkOtCWCUn1kQw.zpGj-9WVni3cQxyOuZbcGA.0hzP1myua3oYpUHwCIY_3edBUREbUpLaX6wYuJduOdI.Ppc6aEO3y3B8BJ1FKMPjlA ; size of compressed JWE: 212 ; eyJhbGciOiJBMTI4S1ciLCJlbmMiOiJBMTI4Q0JDLUhTMjU2In0.N4KeyC7nnSFkieJOyE24_zKeuV_m7v5UKoJb1TgV4Yc_r2RzUPNvyA.6AEdyXSCKx-iMmUJyypSLg.QpixfyrwhGpmwUDp623viik4smPav7vwPLiC2r-V-jwnSfEH3mxWu6DbrIz3mixaqATwynmEBzVPxvS9jTXpSAGCnniib4_0WoPl3r_wF5tlsKOEe--jpNso-DKd1Tp8jJxj3JkFWt3IRnUUKGj17g.sBfDwFc5fzpaI-UW8-SW4g ; size of uncompressed JWE: 303 ; original text from compressed JWE: ; Live long and prosper. ; Live long and prosper. ; Live long and prosper. ; Live long and prosper. ; ; original text from uncompressed JWE: ; Live long and prosper. ; Live long and prosper. ; Live long and prosper. ; Live long and prosper. ; CkStringBuilder::ckDispose(sbPlainText) CkJwe::ckDispose(jwe) CkJsonObject::ckDispose(jweProtHdr) CkStringBuilder::ckDispose(sbJweCompressed) CkStringBuilder::ckDispose(sbJweUncompressed) CkJwe::ckDispose(jwe2) CkStringBuilder::ckDispose(sbOriginalText) ProcedureReturn EndProcedure |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.