Como criar um web service com o PHP utilizando biblioteca nusoap

Tutorial completo de como criar um web service com o PHP (schema SOAP), passo a passo utilizando a biblioteca nusoap.

web service com o PHP

Obviamente não iremos recriar a roda, para criarmos nosso web service iremos utilizar uma biblioteca nusoap.

Clique neste link para baixar: nusoap.

Descompacte o arquivo zip na raiz do seu projeto na pasta lib.

Faça o require do arquivo nusoap.php

require_once('lib/nusoap.php');

Mãos a massa

Uma vez com a biblioteca carregada, vamos ao primeiro passo, começamos instanciando a classe soap_server.

$server = new soap_server();

Definimos o enconding (o arquivo PHP também tem que estar na mesma codificação!)

$server->soap_defencoding = 'UTF-8';
$server->decode_utf8 = false;
$server->encode_utf8 = true;

Configuramos o WSDL

$server->configureWSDL('testws', 'urn:testws');

Agora vamos ao que interessa, registrando um método.

$server->register('processar_nome',array('nome' => 'xsd:string', 'sobrenome' => 'xsd:string'),array('nomecompleto' => 'xsd:string'),'xsd:testws');

Vamos detalhar a função register

  • Primeiro parâmetro: nome da função.
  • Segundo: os campos já com os tipos.
  • Terceiro: os retornos, também já com os tipos.
  • Quarto e ultimo, nome do nosso WS.

E claro, a nossa função.

function processar_nome($nome,$sobrenome){
    return $nome. " " . $sobrenome;
}

Para finalizar temos o código que irá executar os serviços.

$HTTP_RAW_POST_DATA = isset($HTTP_RAW_POST_DATA) ? $HTTP_RAW_POST_DATA : ''; 

$server->service($HTTP_RAW_POST_DATA);

Consultando o WSDL

Acesse o arquivo em seu servidor incluindo no final da URL ?wsdl

Será possível visualizar o XML contendo os dados do seu webservice no padrão SOAP

http://schemas.xmlsoap.org/wsdl/soap/

Testando o Web Service

Siga as orientações deste post: Como consultar um web service (schema soap) pelo PHP

Publicado em PHPPalavras-chave:

Dúvidas? Faça um comentário logo abaixo ou envie uma mensagem clicando aqui.

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *