Sample code for 30+ languages & platforms
Android™

CAdES BES Detached Signature

See more Encryption Examples

Demonstrates how to create a CAdES BES detached signature file (.p7s).

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

    CkCrypt2 crypt = new CkCrypt2();

    // Use a digital certificate and private key from a PFX file (.pfx or .p12).
    String pfxPath = "/Users/chilkat/testData/pfx/acme.pfx";
    String pfxPassword = "test123";

    CkCert cert = new CkCert();
    success = cert.LoadPfxFile(pfxPath,pfxPassword);
    if (success != true) {
        Log.i(TAG, cert.lastErrorText());
        return;
        }

    // Tell the crypt component to use this cert.
    success = crypt.SetSigningCert(cert);
    if (success != true) {
        Log.i(TAG, crypt.lastErrorText());
        return;
        }

    // The CadesEnabled property applies to all methods that create PKCS7 signatures. 
    // To create a CAdES-BES signature, set this property equal to true. 
    crypt.put_CadesEnabled(true);

    // We can sign any type of file, creating a .p7s as output:
    String inFile = "/Users/chilkat/testData/pdf/sample.pdf";
    String sigFile = "/Users/chilkat/testData/p7s/sample.p7s";

    // Create the detached CAdES-BES signature:
    success = crypt.CreateP7S(inFile,sigFile);
    if (success == false) {
        Log.i(TAG, crypt.lastErrorText());
        return;
        }

    success = crypt.VerifyP7S(inFile,sigFile);
    if (success == false) {
        Log.i(TAG, crypt.lastErrorText());
        return;
        }

    Log.i(TAG, "Success!");

  }

  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."
  }
}