Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(MFC) Get Certificates within XML SignatureDemonstrates how to get the certificates contained within an XML signature.
#include <CkStringBuilder.h> #include <CkXmlDSig.h> #include <CkStringArray.h> #include <CkCert.h> void ChilkatSample(void) { CkString strOut; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkStringBuilder sbXml; // Load XML containing one or more signatures. bool success = sbXml.LoadFile("qa_data/xml_dsig_valid_samples/multipleSigners/sp.pdf.XAdES.xml","utf-8"); if (success == false) { strOut.append("Failed to load the XML file.."); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } CkXmlDSig dsig; // 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 != true) { strOut.append(dsig.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // For each signature, verify and also get the certificate(s) contained within each Signature. int i = 0; CkStringArray saCerts; CkCert cert; strOut.append("numSignatures = "); strOut.appendInt(dsig.get_NumSignatures()); strOut.append("\r\n"); while (i < dsig.get_NumSignatures()) { // Select the Nth signature by setting the Selector property. dsig.put_Selector(i); bool bVerifyReferenceDigests = true; bool bVerified = dsig.VerifySignature(bVerifyReferenceDigests); strOut.append("Signature "); strOut.appendInt(i + 1); strOut.append(" verified = "); strOut.appendInt(bVerified); strOut.append("\r\n"); // Get the certificates embedded in this signature. saCerts.Clear(); success = dsig.GetCerts(saCerts); if (success == true) { int j = 0; while (j < saCerts.get_Count()) { success = cert.LoadFromBase64(saCerts.getString(j)); if (success == true) { strOut.append(" "); strOut.append(cert.subjectDN()); strOut.append("\r\n"); } j = j + 1; } } i = i + 1; } SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.