|  | 
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
| (PHP ActiveX) JWE using "dir" Direct use of Shared Symmetric KeyDemonstrates how to create a JWE using the "dir" alg -- which is to directly use a shared symmetric key. Note: This example requires Chilkat v9.5.0.66 or greater. 
 <?php // 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. $plaintext = 'Live long and prosper.'; // For versions of Chilkat < 10.0.0, use new COM('Chilkat_9_5_0.Chilkat.Jwe') $jwe = new COM("Chilkat.Jwe"); // First build the JWE Protected Header.. // For versions of Chilkat < 10.0.0, use new COM('Chilkat_9_5_0.Chilkat.JsonObject') $jweProtHdr = new COM("Chilkat.JsonObject"); $jweProtHdr->AppendString('alg','dir'); $jweProtHdr->AppendString('enc','A128GCM'); // Don't forget to actually provide the protected header to the JWE object: $jwe->SetProtectedHeader($jweProtHdr); // The JWE is to use 128-bit AES GCM encryption as specified by the "enc" parameter. // Given that the "alg" = "dir", we are to directly specify the AES GCM key. // (It is assumed that the decrypting side also has knowledge of the direct key to be used..) // Our key will be these 16 hex bytes: 000102030405060708090A0B0C0D0E0F // The SetWrappingKey method is also used for "dir" direct keys. // However, if there are multiple recipients, they must all share the same CEK (Content Encryption Key), // which is specified by calling SetWrappingKey with an index of 0. $recipientIndex = 0; $jwe->SetWrappingKey($recipientIndex,'000102030405060708090A0B0C0D0E0F','hex'); // Encrypt and return the JWE: $strJwe = $jwe->encrypt($plaintext,'utf-8'); if ($jwe->LastMethodSuccess != 1) { print $jwe->LastErrorText . "\n"; exit; } // Show the JWE we just created: print $strJwe . "\n"; // Decrypt the JWE. // For versions of Chilkat < 10.0.0, use new COM('Chilkat_9_5_0.Chilkat.Jwe') $jwe2 = new COM("Chilkat.Jwe"); $success = $jwe2->LoadJwe($strJwe); if ($success != 1) { print $jwe2->LastErrorText . "\n"; exit; } $jwe2->SetWrappingKey(0,'000102030405060708090A0B0C0D0E0F','hex'); // Decrypt. $originalPlaintext = $jwe2->decrypt(0,'utf-8'); if ($jwe2->LastMethodSuccess != 1) { print $jwe2->LastErrorText . "\n"; exit; } print 'original text: ' . "\n"; print $originalPlaintext . "\n"; // Sample output: // eyJhbGciOiJkaXIiLCJlbmMiOiJBMTI4R0NNIn0..20HX5Huc7f1nQC4pBUtiCQ.axFZIxtZy5j0ifJQUzGXLKIpsBuxJA.eBrOC-NrsreN6JeGuOPk1g // original text: // Live long and prosper. ?> | ||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.