Sample code for 30+ languages & platforms
Objective-C

Sign a Byte Array to Create an Opaque Signature in a Byte Array

See more Digital Signatures Examples

Signs data contained in a byte array to produce an opaque signature (also in a byte array). An opaque signature is a PKCS7 signature (also known as CAdES) that embeds the signed data. Also shows how to verify the signature and extract the original data.

Chilkat Objective-C Downloads

Objective-C
#import <CkoCert.h>
#import <CkoFileAccess.h>
#import <CkoCrypt2.h>

BOOL success = NO;

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

CkoCert *cert = [[CkoCert alloc] init];
success = [cert LoadPfxFile: @"qa_data/pfx/cert_test123.pfx" password: @"test123"];
if (success == NO) {
    NSLog(@"%@",cert.LastErrorText);
    return;
}

CkoFileAccess *fac = [[CkoFileAccess alloc] init];

NSData fileBytes;
fileBytes = [fac ReadEntireFile: @"qa_data/pdf/sample.pdf"];
if (fac.LastMethodSuccess != YES) {
    NSLog(@"%@",fac.LastErrorText);
    return;
}

CkoCrypt2 *crypt = [[CkoCrypt2 alloc] init];

success = [crypt SetSigningCert: cert];

// We can sign any type of file.

NSData sigBytes;
sigBytes = [crypt OpaqueSignBytes: fileBytes];
if (crypt.LastMethodSuccess != YES) {
    NSLog(@"%@",crypt.LastErrorText);
    return;
}

success = [fac WriteEntireFile: @"qa_output/sample.pdf.p7m" fileData: sigBytes];
if (fac.LastMethodSuccess != YES) {
    NSLog(@"%@",fac.LastErrorText);
    return;
}

// We can verify the opaque signature and extract the original data like this
NSData originalData;
originalData = [crypt OpaqueVerifyBytes: sigBytes];
if (crypt.LastMethodSuccess != YES) {
    NSLog(@"%@",crypt.LastErrorText);
    return;
}

success = [fac WriteEntireFile: @"qa_output/sample.pdf" fileData: originalData];
if (fac.LastMethodSuccess != YES) {
    NSLog(@"%@",fac.LastErrorText);
    return;
}

NSLog(@"%@",@"Signature is verified and the original data was extracted.");