|
|
(JavaScript) palena.sii.cl getToken SOAP Request
Demonstrates how to call getToken SOAP request at palena.sii.cl
var success = false;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// Create the XML to be signed...
var xmlToSign = new CkXml();
xmlToSign.Tag = "getToken";
// This is the seed obtained from palena.sii.cl getSeed
xmlToSign.UpdateChildContent("item|Semilla","033878794660");
var gen = new CkXmlDSigGen();
gen.SigLocation = "getToken";
gen.SigLocationMod = 0;
gen.SigNamespacePrefix = "";
gen.SigNamespaceUri = "http://www.w3.org/2000/09/xmldsig#";
gen.SignedInfoCanonAlg = "EXCL_C14N";
gen.SignedInfoDigestMethod = "sha1";
gen.AddSameDocRef("","sha1","","","");
// Provide a certificate + private key. (PFX password is test123)
var cert = new CkCert();
success = cert.LoadPfxFile("qa_data/pfx/cert_test123.pfx","test123");
if (success == false) {
console.log(cert.LastErrorText);
return;
}
gen.SetX509Cert(cert,true);
gen.KeyInfoType = "X509Data";
gen.X509Type = "Certificate";
// Load XML to be signed...
var sbXml = new CkStringBuilder();
xmlToSign.EmitXmlDecl = false;
xmlToSign.GetXmlSb(sbXml);
gen.Behaviors = "IndentedSignature";
// Sign the XML...
success = gen.CreateXmlDSigSb(sbXml);
if (success == false) {
console.log(gen.LastErrorText);
return;
}
// -----------------------------------------------
var http = new CkHttp();
var responseStatusCode;
http.UncommonOptions = "AllowEmptyHeaders";
http.SetRequestHeader("SOAPAction","");
// The endpoint for this soap service is:
var endPoint = "https://palena.sii.cl/DTEWS/GetTokenFromSeed.jws";
// Send the following SOAP XML
// <soapenv:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:def="http://DefaultNamespace">
// <soapenv:Header/>
// <soapenv:Body>
// <def:getToken soapenv:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
// <pszXml>SIGNED_XML_GOES_HERE</pszXml>
// </def:getToken>
// </soapenv:Body>
// </soapenv:Envelope>
var xml = new CkXml();
xml.Tag = "soapenv:Envelope";
xml.AddAttribute("xmlns:xsi","http://www.w3.org/2001/XMLSchema-instance");
xml.AddAttribute("xmlns:xsd","http://www.w3.org/2001/XMLSchema");
xml.AddAttribute("xmlns:soapenv","http://schemas.xmlsoap.org/soap/envelope/");
xml.AddAttribute("xmlns:def","http://DefaultNamespace");
xml.UpdateChildContent("soapenv:Header","");
xml.UpdateAttrAt("soapenv:Body|def:getToken",true,"soapenv:encodingStyle","http://schemas.xmlsoap.org/soap/encoding/");
xml.UpdateChildContent("soapenv:Body|def:getToken|pszXml","SIGNED_XML_GOES_HERE");
// We must replace the "SIGNED_XML_GOES_HERE" with the exact contents of the signed XML to ensure the signed XML is not modified in any way.
var sbSoapXml = new CkStringBuilder();
sbSoapXml.Append(xml.GetXml());
var numReplaced = sbXml.Replace("&","&");
numReplaced = sbXml.Replace(">",">");
numReplaced = sbXml.Replace("<","<");
numReplaced = sbXml.Replace("\"",""");
numReplaced = sbSoapXml.Replace("SIGNED_XML_GOES_HERE",sbXml.GetAsString());
var xmlStr = sbSoapXml.GetAsString();
var resp = new CkHttpResponse();
success = http.HttpStr("POST",endPoint,xmlStr,"utf-8","text/xml",resp);
if (success == false) {
console.log(http.LastErrorText);
return;
}
responseStatusCode = resp.StatusCode;
console.log("Response Status Code: " + responseStatusCode);
// You may examine the exact HTTP header sent with the POST like this:
console.log("LastHeader:");
console.log(http.LastHeader);
// Examine the XML returned by the web service:
console.log("XML Response:");
var xmlResp = new CkXml();
xmlResp.LoadXml(resp.BodyStr);
console.log(xmlResp.GetXml());
// Use this online tool to generate parsing code from response XML:
// Generate Parsing Code from XML
|