Sample code for 30+ languages & platforms
Objective-C

Verify the RSA Signature of a SHA256 Hash

See more RSA Examples

Demonstrates how to verify an RSA signature of a SHA256 hash.

Chilkat Objective-C Downloads

Objective-C
#import <CkoPublicKey.h>
#import <CkoRsa.h>
#import <CkoBinData.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.

// Let's say you have a file containing the 32-bytes of a SHA256 hash,
// and a file that is an RSA signature of those 32 bytes.
// Here's how you verify using the RSA public key found in a PEM.

CkoPublicKey *pubKey = [[CkoPublicKey alloc] init];
success = [pubKey LoadFromFile: @"rsaPubKey.pem"];
if (success == NO) {
    NSLog(@"%@",pubKey.LastErrorText);
    return;
}

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

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

// Get the 32-byte SHA256 hash.
CkoBinData *bdHash = [[CkoBinData alloc] init];
success = [bdHash LoadFile: @"myHash.sha256"];
if (success == NO) {
    NSLog(@"%@",@"Failed to load SHA256 hash.");
    return;
}

// Get the RSA signature to be validated.
CkoBinData *bdSig = [[CkoBinData alloc] init];
success = [bdSig LoadFile: @"mySig.sig"];
if (success == NO) {
    NSLog(@"%@",@"Failed to load RSA signature.");
    return;
}

// Verify the signature against the SHA256 hash.
NSString *enc = @"base64";
rsa.EncodingMode = enc;
success = [rsa VerifyHashENC: [bdHash GetEncoded: enc] hashAlg: @"sha256" encodedSig: [bdSig GetEncoded: enc]];
if (success == NO) {
    NSLog(@"%@",rsa.LastErrorText);
    return;
}

NSLog(@"%@",@"Signature validated.");