Java
Java
RSA Encrypt and Decrypt Credit Card Numbers
See more RSA Examples
_LANGUAGE_ sample code to RSA public-key encrypt and decrypt credit card numbers. The RSA key is loaded from an unencrypted PKCS8 file. Chilkat provides many ways of setting the key -- loading from both encrypted and unencrypted PEM, PKCS8, DER, PVK, etc. Keys may be loaded from files or in-memory representations. (The RSA component also provides the ability to generate RSA keys.)Chilkat Java Downloads
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.
CkRsa rsa = new CkRsa();
CkPrivateKey privKey = new CkPrivateKey();
// Load an RSA private key from a file:
success = privKey.LoadAnyFormatFile("rsaPrivateKey.key","");
if (success == false) {
System.out.println(privKey.lastErrorText());
return;
}
// Get the public part of the private key.
CkPublicKey pubKey = new CkPublicKey();
privKey.ToPublicKey(pubKey);
success = rsa.UsePublicKey(pubKey);
if (success == false) {
System.out.println(rsa.lastErrorText());
return;
}
// Encrypt a VISA credit card number:
// 1234-5678-0000-9999
String ccNumber = "1234567800009999";
boolean usePrivateKey = false;
rsa.put_EncodingMode("base64");
String encryptedStr = rsa.encryptStringENC(ccNumber,usePrivateKey);
System.out.println("Encrypted:");
System.out.println(encryptedStr);
// Now decrypt:
CkRsa rsaDecryptor = new CkRsa();
rsaDecryptor.put_EncodingMode("base64");
rsaDecryptor.UsePrivateKey(privKey);
usePrivateKey = true;
String decryptedStr = rsaDecryptor.decryptStringENC(encryptedStr,usePrivateKey);
System.out.println("Decrypted:");
System.out.println(decryptedStr);
// Important: RSA encryption should only be used to encrypt small amounts of data.
// It is typically used for encrypting symmetric encryption
// keys such that a symmetric encryption algorithm, such as
// AES is then used to encrypt/decrypt bulk data
}
}