Sample code for 30+ languages & platforms
Android™

Send Encrypted Email to Multiple Recipients

Demonstrates how to create and send an S/MIME encrypted email to multiple recipients. The digital certificate of each recipient is required. The encrypting/sending process uses each recipient's digital certificate (which internally contains the public key). Each recipient decrypts the received email using his/her private key.

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.

    // The mailman object is used for sending and receiving email.
    CkMailMan mailman = new CkMailMan();

    // Set the SMTP server.
    mailman.put_SmtpHost("smtp.mymailserver.com");

    // Load each recipient's certificate into a Chilkat certificate object.
    // This example loads the certificates from files.  However, the Chilkat
    // certificate object provides other means for loading certificates,
    // such as from in-memory PEM strings, or in-memory binary DER encoded form, etc.
    CkCert cert1 = new CkCert();
    success = cert1.LoadFromFile("recipient1.cer");
    if (success != true) {
        Log.i(TAG, cert1.lastErrorText());
        return;
        }

    CkCert cert2 = new CkCert();
    success = cert2.LoadFromFile("recipient2.cer");
    if (success != true) {
        Log.i(TAG, cert2.lastErrorText());
        return;
        }

    CkCert cert3 = new CkCert();
    success = cert3.LoadFromFile("recipient3.cer");
    if (success != true) {
        Log.i(TAG, cert3.lastErrorText());
        return;
        }

    // Create a new email object
    CkEmail email = new CkEmail();

    email.put_Subject("This email is encrypted and sent to 3 recipients");
    email.put_Body("This is an S/MIME encrypted mail sent to 3 recipients");
    email.put_From("Chilkat Support <support@chilkatsoft.com>");

    // Make each of the certificates available for encrypting the email
    // by calling AddEncryptCert for each.
    success = email.AddEncryptCert(cert1);
    if (success == true) {
        success = email.AddEncryptCert(cert2);
        }

    if (success == true) {
        success = email.AddEncryptCert(cert3);
        }

    if (success != true) {
        Log.i(TAG, email.lastErrorText());
        return;
        }

    // Add 3 recipients to the email (2 TO addresses, and 1 CC address)
    success = email.AddTo("Recipient 1","admin@cknotes.com");
    success = email.AddTo("Recipient 2","somebody001122@yahoo.com");
    success = email.AddCC("Recipient 3","somebody123xyz@gmail.com");

    // Indicate that the email is to be sent encrypted.
    email.put_SendEncrypted(true);

    // Send the encrypted email...
    success = mailman.SendEmail(email);
    if (success != true) {
        Log.i(TAG, mailman.lastErrorText());
        }
    else {
        Log.i(TAG, "Encrypted Email Sent!");
        }


  }

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