Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Objective-C) Get Certificates within XML SignatureDemonstrates how to get the certificates contained within an XML signature.
#import <CkoStringBuilder.h> #import <CkoXmlDSig.h> #import <CkoStringArray.h> #import <CkoCert.h> // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkoStringBuilder *sbXml = [[CkoStringBuilder alloc] init]; // Load XML containing one or more signatures. BOOL success = [sbXml LoadFile: @"qa_data/xml_dsig_valid_samples/multipleSigners/sp.pdf.XAdES.xml" charset: @"utf-8"]; if (success == NO) { NSLog(@"%@",@"Failed to load the XML file.."); return; } CkoXmlDSig *dsig = [[CkoXmlDSig alloc] init]; // First load the XML containing the signatures to be verified. // Note that this particular Signature already contains the RSA public key that will be used // for verification. success = [dsig LoadSignatureSb: sbXml]; if (success != YES) { NSLog(@"%@",dsig.LastErrorText); return; } // For each signature, verify and also get the certificate(s) contained within each Signature. int i = 0; CkoStringArray *saCerts = [[CkoStringArray alloc] init]; CkoCert *cert = [[CkoCert alloc] init]; NSLog(@"%@%d",@"numSignatures = ",[dsig.NumSignatures intValue]); while (i < [dsig.NumSignatures intValue]) { // Select the Nth signature by setting the Selector property. dsig.Selector = [NSNumber numberWithInt: i]; BOOL bVerifyReferenceDigests = YES; BOOL bVerified = [dsig VerifySignature: bVerifyReferenceDigests]; NSLog(@"%@%d%@%d",@"Signature ",i + 1,@" verified = ",bVerified); // Get the certificates embedded in this signature. [saCerts Clear]; success = [dsig GetCerts: saCerts]; if (success == YES) { int j = 0; while (j < [saCerts.Count intValue]) { success = [cert LoadFromBase64: [saCerts GetString: [NSNumber numberWithInt: j]]]; if (success == YES) { NSLog(@"%@%@",@" ",cert.SubjectDN); } j = j + 1; } } i = i + 1; } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.