Sample code for 30+ languages & platforms
Java

Get ETK Public Key (api-acpt.ehealth.fgov.be)

See more Belgian eHealth Platform Examples

The following URL returns JSON, which contains a PKCS7 signed data:
https://api-acpt.ehealth.fgov.be/etee/v1/etks?identifier=12345678901&type=SSIN

This example extracts the signed data, validates it, and then extracts the public key from the certificate (obtained from signed content in the PKCS7)

Note: The URL above uses "12345678901" which is not valid. You should replace it with a valid number.

Chilkat Java Downloads

Java
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 example requires the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    CkHttp http = new CkHttp();

    String jsonStr = http.quickGetStr("https://api-acpt.ehealth.fgov.be/etee/v1/etks?identifier=12345678901&type=SSIN");
    if (http.get_LastMethodSuccess() == false) {
        System.out.println(http.lastErrorText());
        return;
        }

    System.out.println(jsonStr);

    // The JSON contains something like this:

    // [
    //     {
    //         "key": {
    //             "applicationIdentifier": "",
    //             "ssin": "12345678901"
    //         },
    //         "value": "MIAGCSq....AAAAAAAA=="
    //     }
    // ]

    // Note: The above is a JSON array (not a JSON object)
    // It should be loaded into a Chilkat JSON array.
    CkJsonArray jarr = new CkJsonArray();
    success = jarr.Load(jsonStr);
    if (success == false) {
        System.out.println("Failed to load JSON.");
        return;
        }

    CkJsonObject json = jarr.ObjectAt(0);
    CkBinData bdPkcs7 = new CkBinData();
    bdPkcs7.AppendEncoded(json.stringOf("value"),"base64");

    // Let's verify the PKCS7, and then examine the signing cert,
    // and get the signing cert's public key.
    CkCrypt2 crypt = new CkCrypt2();

    // Validate the signedData PKCS7, and replace the contents of bdPkcs7 with the extracted signed content.
    success = crypt.OpaqueVerifyBd(bdPkcs7);
    if (success == false) {
        System.out.println(crypt.lastErrorText());
        return;
        }

    // The signed content is the DER of a certificate.
    // In other words, bdPkcs7 now contains a certificate.
    CkCert cert = new CkCert();
    success = cert.LoadFromBd(bdPkcs7);
    if (success == false) {
        System.out.println(cert.lastErrorText());
        return;
        }

    // Show some certificate information:
    System.out.println("Subject: " + cert.subjectDN());
    System.out.println("Serial: " + cert.serialNumber());
    System.out.println("Issuer: " + cert.issuerDN());

    // Let's get the cert's public key...
    CkPublicKey pubKey = new CkPublicKey();
    cert.GetPublicKey(pubKey);

    // OK, you now have the public key and can do whatever is needed..
    System.out.println(pubKey.keyType());
    System.out.println(pubKey.get_KeySize());
  }
}