Sample code for 30+ languages & platforms
Android™

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 Android™ Downloads

Android™
// Important: Don't forget to include the call to System.loadLibrary
// as shown at the bottom of this code sample.
package com.test;

import android.app.Activity;
import com.chilkatsoft.*;

import android.widget.TextView;
import android.os.Bundle;

public class SimpleActivity extends Activity {

  private static final String TAG = "Chilkat";

  // Called when the activity is first created.
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    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) {
        Log.i(TAG, http.lastErrorText());
        return;
        }

    Log.i(TAG, 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) {
        Log.i(TAG, "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) {
        Log.i(TAG, 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) {
        Log.i(TAG, cert.lastErrorText());
        return;
        }

    // Show some certificate information:
    Log.i(TAG, "Subject: " + cert.subjectDN());
    Log.i(TAG, "Serial: " + cert.serialNumber());
    Log.i(TAG, "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..
    Log.i(TAG, pubKey.keyType());
    Log.i(TAG, String.valueOf(pubKey.get_KeySize()));

  }

  static {
      System.loadLibrary("chilkat");

      // Note: If the incorrect library name is passed to System.loadLibrary,
      // then you will see the following error message at application startup:
      //"The application <your-application-name> has stopped unexpectedly. Please try again."
  }
}