Sample code for 30+ languages & platforms
Java

RSA Signature/Verify with .key and .cer

See more RSA Examples

Demonstrates how to use a .key file (private key) and digital certificate (.cer, public key) to create and verify an RSA signature.

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

    CkPrivateKey privKey = new CkPrivateKey();

    // Load the private key from an RSA .key file:
    success = privKey.LoadPemFile("privateKey.key");
    if (success == false) {
        System.out.println(privKey.lastErrorText());
        return;
        }

    CkRsa rsa = new CkRsa();

    // Import the private key into the RSA component:
    success = rsa.UsePrivateKey(privKey);
    if (success == false) {
        System.out.println(rsa.lastErrorText());
        return;
        }

    // Create the signature as a hex string:
    rsa.put_EncodingMode("hex");

    String strData = "This is the string to be signed.";

    // Sign the string using the sha256 hash algorithm.
    // Other valid choices are "md2", "sha1", "sha384",
    // "sha512", and "md5".
    String hexSig = rsa.signStringENC(strData,"sha256");

    System.out.println(hexSig);

    // Load a digital certificate from a .cer file:
    CkCert cert = new CkCert();

    success = cert.LoadFromFile("myCert.cer");
    if (success == false) {
        System.out.println(cert.lastErrorText());
        return;
        }

    CkPublicKey pubKey = new CkPublicKey();
    cert.GetPublicKey(pubKey);

    // Now verify using a new instance of the RSA object:
    CkRsa rsa2 = new CkRsa();

    // Import the public key into the RSA object:
    success = rsa2.UsePublicKey(pubKey);
    if (success == false) {
        System.out.println(rsa2.lastErrorText());
        return;
        }

    // The signature is a hex string, so make sure the EncodingMode is correct:
    rsa2.put_EncodingMode("hex");

    // Verify the signature:
    success = rsa2.VerifyStringENC(strData,"sha256",hexSig);
    if (success == false) {
        System.out.println(rsa2.lastErrorText());
        return;
        }

    System.out.println("Success.");
  }
}