Sample code for 30+ languages & platforms
Objective-C

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 Objective-C Downloads

Objective-C
#import <CkoRsa.h>
#import <CkoPrivateKey.h>
#import <CkoPublicKey.h>
#import <NSString.h>

BOOL success = NO;

// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

CkoRsa *rsa = [[CkoRsa alloc] init];

CkoPrivateKey *privKey = [[CkoPrivateKey alloc] init];

// Load an RSA private key from a file:
success = [privKey LoadAnyFormatFile: @"rsaPrivateKey.key" password: @""];
if (success == NO) {
    NSLog(@"%@",privKey.LastErrorText);
    return;
}

// Get the public part of the private key.
CkoPublicKey *pubKey = [[CkoPublicKey alloc] init];
[privKey ToPublicKey: pubKey];

success = [rsa UsePublicKey: pubKey];
if (success == NO) {
    NSLog(@"%@",rsa.LastErrorText);
    return;
}

// Encrypt a VISA credit card number:
// 1234-5678-0000-9999
NSString *ccNumber = @"1234567800009999";

BOOL usePrivateKey = NO;
rsa.EncodingMode = @"base64";
NSString *encryptedStr = [rsa EncryptStringENC: ccNumber bUsePrivateKey: usePrivateKey];
NSLog(@"%@",@"Encrypted:");
NSLog(@"%@",encryptedStr);

// Now decrypt:
CkoRsa *rsaDecryptor = [[CkoRsa alloc] init];

rsaDecryptor.EncodingMode = @"base64";
[rsaDecryptor UsePrivateKey: privKey];

usePrivateKey = YES;
NSString *decryptedStr = [rsaDecryptor DecryptStringENC: encryptedStr bUsePrivateKey: usePrivateKey];

NSLog(@"%@",@"Decrypted:");
NSLog(@"%@",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