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
(Excel) 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.
' 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 Dim xml As Chilkat.Xml Set xml = Chilkat.NewXml ' 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> success = xml.LoadXmlFile("qa_data/xml_dsig/sii_cl/test_1.xml") If (success = False) Then Debug.Print "Failed to load initial XML file." Exit Sub End If ' Get a reference to the "DD" element Set ddXml = xml.FindChild("Documento|TED|DD") If (xml.LastMethodSuccess = False) Then Debug.Print "Failed to find DD element" Exit Sub End If ' 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), Dim sbFlattened As Chilkat.StringBuilder Set sbFlattened = Chilkat.NewStringBuilder ddXml.EmitCompact = True ddXml.EmitXmlDecl = False Dim success As Boolean success = 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. Dim privKey As Chilkat.PrivateKey Set privKey = Chilkat.NewPrivateKey success = privKey.LoadAnyFormatFile("qa_data/rsa/rsaPrivKey_pkcs8.pem","") If (success = False) Then Debug.Print privKey.LastErrorText Exit Sub End If Dim rsa As Chilkat.Rsa Set rsa = Chilkat.NewRsa success = rsa.ImportPrivateKeyObj(privKey) rsa.EncodingMode = "base64" rsa.Charset = "iso-8859-1" sig = rsa.SignStringENC(sbFlattened.GetAsString(),"sha1") ' Add the FRMT signature element to the XML. xml.UpdateChildContent "Documento|TED|FRMT",sig success = xml.UpdateAttrAt("Documento|TED|FRMT",True,"algoritmo","SHA1withRSA") ' See what we have: xml.EmitCompact = False xml.EmitXmlDecl = True Debug.Print xml.GetXml() |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.