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
(C) Get Certificates within XML SignatureDemonstrates how to get the certificates contained within an XML signature.
#include <C_CkStringBuilder.h> #include <C_CkXmlDSig.h> #include <C_CkStringArray.h> #include <C_CkCert.h> void ChilkatSample(void) { HCkStringBuilder sbXml; BOOL success; HCkXmlDSig dsig; int i; HCkStringArray saCerts; HCkCert cert; BOOL bVerifyReferenceDigests; BOOL bVerified; int j; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. sbXml = CkStringBuilder_Create(); // Load XML containing one or more signatures. success = CkStringBuilder_LoadFile(sbXml,"qa_data/xml_dsig_valid_samples/multipleSigners/sp.pdf.XAdES.xml","utf-8"); if (success == FALSE) { printf("Failed to load the XML file..\n"); CkStringBuilder_Dispose(sbXml); return; } dsig = CkXmlDSig_Create(); // 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 = CkXmlDSig_LoadSignatureSb(dsig,sbXml); if (success != TRUE) { printf("%s\n",CkXmlDSig_lastErrorText(dsig)); CkStringBuilder_Dispose(sbXml); CkXmlDSig_Dispose(dsig); return; } // For each signature, verify and also get the certificate(s) contained within each Signature. i = 0; saCerts = CkStringArray_Create(); cert = CkCert_Create(); printf("numSignatures = %d\n",CkXmlDSig_getNumSignatures(dsig)); while (i < CkXmlDSig_getNumSignatures(dsig)) { // Select the Nth signature by setting the Selector property. CkXmlDSig_putSelector(dsig,i); bVerifyReferenceDigests = TRUE; bVerified = CkXmlDSig_VerifySignature(dsig,bVerifyReferenceDigests); printf("Signature %d verified = %d\n",i + 1,bVerified); // Get the certificates embedded in this signature. CkStringArray_Clear(saCerts); success = CkXmlDSig_GetCerts(dsig,saCerts); if (success == TRUE) { j = 0; while (j < CkStringArray_getCount(saCerts)) { success = CkCert_LoadFromBase64(cert,CkStringArray_getString(saCerts,j)); if (success == TRUE) { printf(" %s\n",CkCert_subjectDN(cert)); } j = j + 1; } } i = i + 1; } CkStringBuilder_Dispose(sbXml); CkXmlDSig_Dispose(dsig); CkStringArray_Dispose(saCerts); CkCert_Dispose(cert); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.