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++) SII Chile - FRMT Signature Computation and Add to XMLCompute the FRMT signature and add to the XML. This is the RSA signature of the SHA-1 digest of the "flattened" DD element.
#include <CkXml.h> #include <CkStringBuilder.h> #include <CkPrivateKey.h> #include <CkRsa.h> void ChilkatSample(void) { // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // Also see: Compute the FRMA 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> // <FRMA algoritmo="SHA1withRSA">...</FRMA> // </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_1.xml"); if (success == false) { std::cout << "Failed to load initial XML file." << "\r\n"; return; } // Get a reference to the "DD" element CkXml *ddXml = xml.FindChild("Documento|TED|DD"); if (xml.get_LastMethodSuccess() == false) { std::cout << "Failed to find DD element" << "\r\n"; return; } // We need to get the "flattened" DD 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; ddXml->put_EmitCompact(true); ddXml->put_EmitXmlDecl(false); ddXml->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) { std::cout << privKey.lastErrorText() << "\r\n"; 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 FRMT signature element to the XML. xml.UpdateChildContent("Documento|TED|FRMT",sig); xml.UpdateAttrAt("Documento|TED|FRMT",true,"algoritmo","SHA1withRSA"); delete ddXml; // See what we have: xml.put_EmitCompact(false); xml.put_EmitXmlDecl(true); std::cout << xml.getXml() << "\r\n"; } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.