Java
Java
JWE using A256GCMKW
See more JSON Web Encryption (JWE) Examples
This example demonstrates creating a JCE with AES GCM key wrap.Chilkat Java Downloads
import com.chilkatsoft.*;
public class ChilkatExample {
static {
try {
System.loadLibrary("chilkat");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load.\n" + e);
System.exit(1);
}
}
public static void main(String argv[])
{
boolean success = false;
// This requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
String plaintext = "My text to enrypt";
CkJwe jwe = new CkJwe();
// First build the JWE Protected Header:
// {
// "alg": "A256GCMKW",
// "kid": "18ec08e1-bfa9-4d95-b205-2b4dd1d4321d",
// "tag": "kfPduVQ3T3H6vnewt--ksw",
// "iv": "KkYT0GX_2jHlfqN_",
// "enc": "A128CBC-HS256"
// }
CkJsonObject jweProtHdr = new CkJsonObject();
jweProtHdr.AppendString("alg","A256GCMKW");
// kid is optional
jweProtHdr.AppendString("kid","18ec08e1-bfa9-4d95-b205-2b4dd1d4321d");
// tag is optional
jweProtHdr.AppendString("tag","kfPduVQ3T3H6vnewt--ksw");
jweProtHdr.AppendString("enc","A256GCM");
// the iv should be 16 random chars.
CkPrng prng = new CkPrng();
jweProtHdr.AppendString("iv",prng.randomString(16,true,true,true));
jwe.SetProtectedHeader(jweProtHdr);
System.out.println("JWE Protected Header: " + jweProtHdr.emit());
System.out.println("--");
// Given that we have 256-bit AES, our key should be 32 bytes.
// The ascii string here is 32 bytes, therefore the 2nd arg is "ascii" to use these
// ascii chars directly as the key.
String aesWrappingKey = "2baf4f730f5e4542b428593ef9cceb0e";
jwe.SetWrappingKey(0,aesWrappingKey,"ascii");
// Encrypt and return the JWE:
String strJwe = jwe.encrypt(plaintext,"utf-8");
if (jwe.get_LastMethodSuccess() != true) {
System.out.println(jwe.lastErrorText());
return;
}
// Show the JWE we just created:
System.out.println(strJwe);
// Decrypt the JWE that was just produced.
// 1) Load the JWE.
// 2) Set the AES wrapping key.
// 3) Decrypt.
CkJwe jwe2 = new CkJwe();
success = jwe2.LoadJwe(strJwe);
if (success != true) {
System.out.println(jwe2.lastErrorText());
return;
}
// Set the AES wrap key. Important to use "ascii"
jwe2.SetWrappingKey(0,aesWrappingKey,"ascii");
// Decrypt.
String originalPlaintext = jwe2.decrypt(0,"utf-8");
if (jwe2.get_LastMethodSuccess() != true) {
System.out.println(jwe2.lastErrorText());
return;
}
System.out.println("original text: ");
System.out.println(originalPlaintext);
}
}