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) SII Chile - FRMA Signature Computation and Add to XMLCompute the FRMA signature of a <DA> element enclosed inside a <CAF> element of the XML to be signed.
#include <CkXml.h> #include <CkStringBuilder.h> #include <CkPrivateKey.h> #include <CkRsa.h> void ChilkatSample(void) { CkString strOut; // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // Also see: Compute the FRMT Signature and Add to XML CkXml xml; // Load the unsigned XML that contains the following: // <DTE version="1.0"> // <Documento ID="F60T33"> // <TED version="1.0"> // <DD> // ... // <CAF version="1.0"> // <DA> // ... // </DA> // ... The FRMA will be added here ... // </CAF> // ... // </DD> // ... The FRMT will be added here in another example ... // </TED> // </Documento> // </DTE> bool success = xml.LoadXmlFile("qa_data/xml_dsig/sii_cl/test_0.xml"); if (success == false) { strOut.append("Failed to load initial XML file."); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Get a reference to the "DA" element CkXml *daXml = xml.FindChild("Documento|TED|DD|CAF|DA"); if (xml.get_LastMethodSuccess() == false) { strOut.append("Failed to find DA element"); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // We need to get the "flattened" DA XML where: // - No whitespace between elements. // - The 5 pre-defined entities are converted. // - The text is encoded in the ISO-8859-1 character set (Latin-1), CkStringBuilder sbFlattened; daXml->put_EmitCompact(true); daXml->put_EmitXmlDecl(false); daXml->GetXmlSb(sbFlattened); // Compute the SHA-1 message digest of the iso-8859-1 byte representation, // and sign it with our RSA private key, getting the result in base64 format. CkPrivateKey privKey; success = privKey.LoadAnyFormatFile("qa_data/rsa/rsaPrivKey_pkcs8.pem",""); if (success == false) { strOut.append(privKey.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } CkRsa rsa; rsa.ImportPrivateKeyObj(privKey); rsa.put_EncodingMode("base64"); rsa.put_Charset("iso-8859-1"); const char *sig = rsa.signStringENC(sbFlattened.getAsString(),"sha1"); // Add the FRMA signature element to the XML. xml.UpdateChildContent("Documento|TED|DD|CAF|FRMA",sig); xml.UpdateAttrAt("Documento|TED|DD|CAF|FRMA",true,"algoritmo","SHA1withRSA"); delete daXml; // See what we have: xml.put_EmitCompact(false); xml.put_EmitXmlDecl(true); strOut.append(xml.getXml()); strOut.append("\r\n"); xml.SaveXml("qa_data/xml_dsig/sii_cl/test_1.xml"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.