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