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
(Visual Basic 6.0) 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 New ChilkatXml ' 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> Dim success As Long success = xml.LoadXmlFile("qa_data/xml_dsig/sii_cl/test_1.xml") If (success = 0) Then Debug.Print "Failed to load initial XML file." Exit Sub End If ' Get a reference to the "DD" element Dim ddXml As ChilkatXml Set ddXml = xml.FindChild("Documento|TED|DD") If (xml.LastMethodSuccess = 0) 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 New ChilkatStringBuilder ddXml.EmitCompact = 1 ddXml.EmitXmlDecl = 0 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 New PrivateKey success = privKey.LoadAnyFormatFile("qa_data/rsa/rsaPrivKey_pkcs8.pem","") If (success = 0) Then Debug.Print privKey.LastErrorText Exit Sub End If Dim rsa As New ChilkatRsa success = rsa.ImportPrivateKeyObj(privKey) rsa.EncodingMode = "base64" rsa.Charset = "iso-8859-1" Dim sig As String 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",1,"algoritmo","SHA1withRSA") ' See what we have: xml.EmitCompact = 0 xml.EmitXmlDecl = 1 Debug.Print xml.GetXml() |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.