Objective-C
Objective-C
Sign a Byte Array to Create a Detached Signature in a Byte Array
See more Digital Signatures Examples
Signs data contained in a byte array to produce a detached signature (also in a byte array). Also shows how to verify the signature.Chilkat Objective-C Downloads
#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.
// The result is a detached signature (a signature that does not contain the data being signed).
NSData sigBytes;
sigBytes = [crypt SignBytes: fileBytes];
if (crypt.LastMethodSuccess != YES) {
NSLog(@"%@",crypt.LastErrorText);
return;
}
success = [fac WriteEntireFile: @"qa_output/sample.pdf.p7s" fileData: sigBytes];
if (fac.LastMethodSuccess != YES) {
NSLog(@"%@",fac.LastErrorText);
return;
}
// We can verify the detached signature like this
BOOL verified = [crypt VerifyBytes: fileBytes sigData: sigBytes];
if (crypt.LastMethodSuccess != YES) {
NSLog(@"%@",crypt.LastErrorText);
return;
}
NSLog(@"%@%d",@"Verified = ",verified);