use chilkat();
$xml = chilkat::CkXml->new();
$xml->put_Tag("soapenv:Envelope");
$xml->AddAttribute("xmlns:ns","http://timbrado.ws.cfdi.solucionfactible.com");
$xml->AddAttribute("xmlns:soapenv","http://schemas.xmlsoap.org/soap/envelope/");
$xml->UpdateChildContent("soapenv:Header","");
$xml->UpdateChildContent("soapenv:Body|ns:cancelar|ns:usuario","string");
$xml->UpdateChildContent("soapenv:Body|ns:cancelar|ns:password","string");
$xml->UpdateChildContent("soapenv:Body|ns:cancelar|ns:uuids","string");
$xml->UpdateChildContent("soapenv:Body|ns:cancelar|ns:derCertCSD","BqozVXeZZg==");
$xml->UpdateChildContent("soapenv:Body|ns:cancelar|ns:derKeyCSD","BqozVXeZZg==");
$xml->UpdateChildContent("soapenv:Body|ns:cancelar|ns:contrasenaCSD","string");
# In a SOAP HTTP request, including the XML declaration (<?xml version="1.0" encoding="UTF-8"?>) in the XML body is generally not required.
$xml->put_EmitXmlDecl(0);
$soapRequestBody = $xml->getXml();
$endpoint = "https://testing.solucionfactible.com/ws/services/Timbrado.TimbradoHttpsSoap11Endpoint/";
$soapAction = "urn:cancelar";
# For SOAP requests, the standard Content-Type is usually set to "text/xml" or "application/soap+xml"
$contentType = "text/xml";
$http = chilkat::CkHttp->new();
$http->ClearHeaders();
$http->SetRequestHeader("Content-Type",$contentType);
$http->SetRequestHeader("SOAPAction",$soapAction);
# resp is a HttpResponse
$resp = $http->PostXml($endpoint,$soapRequestBody,"utf-8");
if ($http->get_LastMethodSuccess() == 0) {
print $http->lastErrorText() . "\r\n";
print"Failed to send SOAP request." . "\r\n";
exit;
}
# Get the XML response body.
$responseXml = chilkat::CkXml->new();
$resp->GetBodyXml($responseXml);
$statusCode = $resp->get_StatusCode();
print"response status code: " . $statusCode . "\r\n";
# If the status code does not indicate succcess, then show the response XML,
# which probably contains error information.if ($statusCode != 200) {
print $responseXml->getXml() . "\r\n";
exit;
}
print $responseXml->getXml() . "\r\n";
# Parse the successful SOAP response XML.# This is a sample of the response XML, but the namespace prefixes will be different.
# We can parse the result using "*" for the namespace prefixes (see below).
$mensaje = $responseXml->getChildContent("*:Body|*:cancelarResponse|*:return|*:mensaje");
$mensaje = $responseXml->getChildContent("*:Body|*:cancelarResponse|*:return|*:resultados|*:mensaje");
$status = $responseXml->GetChildIntValue("*:Body|*:cancelarResponse|*:return|*:resultados|*:status");
$statusUUID = $responseXml->getChildContent("*:Body|*:cancelarResponse|*:return|*:resultados|*:statusUUID");
$uuid = $responseXml->getChildContent("*:Body|*:cancelarResponse|*:return|*:resultados|*:uuid");
$status = $responseXml->GetChildIntValue("*:Body|*:cancelarResponse|*:return|*:status");