Sample code for 30+ languages & platforms
Android™

Client Certificate in REST

See more REST Examples

Demonstrates how to use a client certificate with a REST connection.

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.

    // This example shows how to use the Chilkat socket object's connection.
    CkRest rest = new CkRest();
    CkSocket socket = new CkSocket();

    // Set the certificate to be used for mutual TLS authentication
    // (i.e. sets the client-side certificate for two-way TLS authentication)
    // Note: There are other ways to set the client certificate using Chilkat.
    // For example, on Windows systems, a Chilkat certificate object could be loaded with certificate
    // pre-installed (with private key) in a Windows certificate store, and then socket.SetSslClientCert could be called.
    success = socket.SetSslClientCertPfx("/home/bob/pfxFiles/myClientSideCertWithPrivateKey.pfx","pfxPassword");
    if (success != true) {
        Log.i(TAG, socket.lastErrorText());
        return;
        }

    // Note: The certificate used for the client-side of TLS mutual authentication
    // must have the associated private key available. (.pfx/.p12 files typically store both
    // the certificate and associated private key.)

    // Establish the connection using the socket object (with client certificate authentication).
    boolean bTls = true;
    int port = 443;
    int maxWaitMs = 5000;
    success = socket.Connect("www.example.com",port,bTls,maxWaitMs);
    if (success != true) {
        Log.i(TAG, "Connect Failure Error Code: " + String.valueOf(socket.get_ConnectFailReason()));
        Log.i(TAG, socket.lastErrorText());
        return;
        }

    boolean bAutoReconnect = true;

    // Use the connection:
    success = rest.UseConnection(socket,bAutoReconnect);
    if (success != true) {
        Log.i(TAG, rest.lastErrorText());
        return;
        }

    // At this point we are connected and can make REST calls...
    // For example..
    String responseJson = rest.fullRequestNoBody("GET","/someQuery");
    if (rest.get_LastMethodSuccess() != true) {
        Log.i(TAG, rest.lastErrorText());
        return;
        }


  }

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