SOAP WSDL Generate Code

BasicHttpBinding_IConsultaCFDIService / Consulta

ASP AutoIt C C (Unicode) C++ C++ (Unicode) C# DataFlex Delphi Foxpro Go Java Node.js Objective-C Perl PHP Extension PowerBuilder Powershell PureBasic Python CkPython Ruby SQL Server Swift TCL VB.NET VB6 VBScript Xojo
<?php

include("chilkat_9_5_0.php");

$xml = new CkXml();
$xml->put_Tag('soapenv:Envelope');
$xml->AddAttribute('xmlns:soapenv','http://schemas.xmlsoap.org/soap/envelope/');
$xml->AddAttribute('xmlns:tem','http://tempuri.org/');
$xml->UpdateChildContent('soapenv:Header','');
$xml->UpdateChildContent('soapenv:Body|tem:Consulta|tem:expresionImpresa','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(false);
$soapRequestBody = $xml->getXml();

$endpoint = 'https://consultaqr.facturaelectronica.sat.gob.mx/ConsultaCFDIService.svc';
$soapAction = 'http://tempuri.org/IConsultaCFDIService/Consulta';
//  For SOAP requests, the standard Content-Type is usually set to "text/xml" or "application/soap+xml"
$contentType = 'text/xml';

$http = new CkHttp();

$http->ClearHeaders();
$http->SetRequestHeader('Content-Type',$contentType);
$http->SetRequestHeader('SOAPAction',$soapAction);

// resp is a CkHttpResponse
$resp = $http->PostXml($endpoint,$soapRequestBody,'utf-8');
if ($http->get_LastMethodSuccess() == false) {
    print $http->lastErrorText() . "\n";
    print 'Failed to send SOAP request.' . "\n";
    exit;
}

// Get the XML response body.
$responseXml = new CkXml();
$resp->GetBodyXml($responseXml);

$statusCode = $resp->get_StatusCode();
print 'response status code: ' . $statusCode . "\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() . "\n";
    exit;
}

print $responseXml->getXml() . "\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).

$CodigoEstatus = $responseXml->getChildContent('*:Body|*:ConsultaResponse|*:ConsultaResult|*:CodigoEstatus');
$EsCancelable = $responseXml->getChildContent('*:Body|*:ConsultaResponse|*:ConsultaResult|*:EsCancelable');
$Estado = $responseXml->getChildContent('*:Body|*:ConsultaResponse|*:ConsultaResult|*:Estado');
$EstatusCancelacion = $responseXml->getChildContent('*:Body|*:ConsultaResponse|*:ConsultaResult|*:EstatusCancelacion');
$ValidacionEFOS = $responseXml->getChildContent('*:Body|*:ConsultaResponse|*:ConsultaResult|*:ValidacionEFOS');

?>
Request XML
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:tem="http://tempuri.org/">
    <soapenv:Header/>
    <soapenv:Body>
        <tem:Consulta>
            <tem:expresionImpresa>string</tem:expresionImpresa>
        </tem:Consulta>
    </soapenv:Body>
</soapenv:Envelope>
Response XML
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:tem="http://tempuri.org/" xmlns:sat="http://schemas.datacontract.org/2004/07/Sat.Cfdi.Negocio.ConsultaCfdi.Servicio">
    <soapenv:Header/>
    <soapenv:Body>
        <tem:ConsultaResponse>
            <tem:ConsultaResult>
                <sat:CodigoEstatus>string</sat:CodigoEstatus>
                <sat:EsCancelable>string</sat:EsCancelable>
                <sat:Estado>string</sat:Estado>
                <sat:EstatusCancelacion>string</sat:EstatusCancelacion>
                <sat:ValidacionEFOS>string</sat:ValidacionEFOS>
            </tem:ConsultaResult>
        </tem:ConsultaResponse>
    </soapenv:Body>
</soapenv:Envelope>