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