Sample code for 30+ languages & platforms
Objective-C

RSA Encrypt and Decrypt Strings

See more RSA Examples

_LANGUAGE_ sample code to RSA public-key encrypt and decrypt strings using public and private 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];

// This example also generates the public and private
// keys to be used in the RSA encryption.
// Normally, you would generate a key pair once,
// and distribute the public key to your partner.
// Anything encrypted with the public key can be
// decrypted with the private key.  The reverse is 
// also true: anything encrypted using the private
// key can be decrypted using the public key.

// Generate a 2048-bit key.  Chilkat RSA supports
// key sizes ranging from 512 bits to 4096 bits.
CkoPrivateKey *privKey = [[CkoPrivateKey alloc] init];
success = [rsa GenKey: [NSNumber numberWithInt: 2048] privKey: privKey];
if (success == NO) {
    NSLog(@"%@",rsa.LastErrorText);
    return;
}

CkoPublicKey *pubKey = [[CkoPublicKey alloc] init];
[privKey ToPublicKey: pubKey];

NSString *plainText = @"Encrypting and decrypting should be easy!";

// Start with a new RSA object to demonstrate that all we
// need are the keys previously exported:
CkoRsa *rsaEncryptor = [[CkoRsa alloc] init];

// Encrypted output is always binary.  In this case, we want
// to encode the encrypted bytes in a printable string.
// Our choices are "hex", "base64", "url", "quoted-printable".
rsaEncryptor.EncodingMode = @"hex";

// We'll encrypt with the public key and decrypt with the private
// key.
success = [rsaEncryptor UsePublicKey: pubKey];

BOOL usePrivateKey = NO;
NSString *encryptedStr = [rsaEncryptor EncryptStringENC: plainText bUsePrivateKey: usePrivateKey];
NSLog(@"%@",encryptedStr);

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

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

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

NSLog(@"%@",decryptedStr);