|
|
(JavaScript) SOAP Request to fseservicetest.sanita.finanze.it with Smart Card Authentication (TS-CNS Italian Card)
Demonstrates sending a SOAP request to fseservicetest.sanita.finanze.it with Smart Card (TS-CNS Italian Card).
var success = false;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
var http = new CkHttp();
var xml = new CkXml();
success = false;
// --------------------------------------------------------------------------------
// Also see Chilkat's Online WSDL Code Generator
// to generate code and SOAP Request and Response XML for each operation in a WSDL.
// --------------------------------------------------------------------------------
// Create the SOAP envelope...
xml.Tag = "soapenv:Envelope";
xml.AddAttribute("xmlns:soapenv","http://schemas.xmlsoap.org/soap/envelope/");
xml.AddAttribute("xmlns:stat","http://statoconsensirichiesta.xsd.fse.ini.finanze.it");
xml.AddAttribute("xmlns:tip","http://tipodatistatoconsensi.xsd.fse.ini.finanze.it");
xml.UpdateChildContent("soapenv:Header","");
xml.UpdateChildContent("soapenv:Body|stat:StatoConsensiRichiesta|stat:IdentificativoUtente","XXXXXXAAABBBCCC");
xml.UpdateChildContent("soapenv:Body|stat:StatoConsensiRichiesta|stat:pinCode","...");
xml.UpdateChildContent("soapenv:Body|stat:StatoConsensiRichiesta|stat:IdentificativoOrganizzazione","999");
xml.UpdateChildContent("soapenv:Body|stat:StatoConsensiRichiesta|stat:StrutturaUtente","123456789");
xml.UpdateChildContent("soapenv:Body|stat:StatoConsensiRichiesta|stat:RuoloUtente","ZZZ");
xml.UpdateChildContent("soapenv:Body|stat:StatoConsensiRichiesta|stat:ContestoOperativo","");
xml.UpdateChildContent("soapenv:Body|stat:StatoConsensiRichiesta|stat:IdentificativoAssistitoGenitoreTutore","");
xml.UpdateChildContent("soapenv:Body|stat:StatoConsensiRichiesta|stat:PresaInCarico","true");
xml.UpdateChildContent("soapenv:Body|stat:StatoConsensiRichiesta|stat:TipoAttivita","READ");
xml.UpdateChildContent("soapenv:Body|stat:StatoConsensiRichiesta|stat:IdentificativoAssistitoConsenso","ABCDEFGHIJKLM");
var soapEnvelope = xml.GetXml();
var domain = "fseservicetest.sanita.finanze.it";
var path = "/FseInsServicesWeb/services/fseStatoConsensi";
var req = new CkHttpRequest();
req.HttpVerb = "POST";
req.SendCharset = false;
req.AddHeader("Content-Type","application/soap+xml; charset=utf-8");
req.Path = path;
success = req.LoadBodyFromString(soapEnvelope,"utf-8");
// Load the default certificate from the smartcard currently in the reader.
// (This assumes only one reader with one smartcard containing one certificate.
// If the situation is more complex, you can do it with Chilkat, but it requires
// using the Chilkat certificate store object to get the desired certificate
// from the desired smart card.)
//
// Note: This is for Windows-only.
var cert = new CkCert();
success = cert.LoadFromSmartcard("");
if (success == false) {
console.log(cert.LastErrorText);
return;
}
// Tell the Chilkat HTTP object to use the certificate for client authentication.
success = http.SetSslClientCert(cert);
if (success == false) {
console.log(http.LastErrorText);
return;
}
http.TlsVersion = "TLS 1.1";
var resp = new CkHttpResponse();
success = http.HttpSReq(domain,443,true,req,resp);
if (success == false) {
console.log(http.LastErrorText);
return;
}
var xmlResp = new CkXml();
success = xmlResp.LoadXml(resp.BodyStr);
console.log(xmlResp.GetXml());
|