Java
Java
SII Chile - FRMT Signature Computation and Add to XML
See more XML Digital Signatures Examples
Compute the FRMT signature and add to the XML. This is the RSA signature of the SHA-1 digest of the "flattened" DD element.Chilkat Java Downloads
import com.chilkatsoft.*;
public class ChilkatExample {
static {
try {
System.loadLibrary("chilkat");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load.\n" + e);
System.exit(1);
}
}
public static void main(String argv[])
{
boolean success = false;
// 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 = new CkXml();
// 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) {
System.out.println("Failed to load initial XML file.");
return;
}
// Get a reference to the "DD" element
CkXml ddXml = xml.FindChild("Documento|TED|DD");
if (xml.get_LastMethodSuccess() == false) {
System.out.println("Failed to find DD element");
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 = new CkStringBuilder();
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 = new CkPrivateKey();
success = privKey.LoadAnyFormatFile("qa_data/rsa/rsaPrivKey_pkcs8.pem","");
if (success == false) {
System.out.println(privKey.lastErrorText());
return;
}
CkRsa rsa = new CkRsa();
rsa.UsePrivateKey(privKey);
rsa.put_EncodingMode("base64");
rsa.put_Charset("iso-8859-1");
String 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");
// See what we have:
xml.put_EmitCompact(false);
xml.put_EmitXmlDecl(true);
System.out.println(xml.getXml());
}
}