Eu entendo que seu problema se resume a como chamar um serviço da web SOAP (JAX-WS) de Java e obter seu objeto de retorno . Nesse caso, você tem duas abordagens possíveis:
- Gere as classes Java por meio
wsimport
delas e as use; ou
- Crie um cliente SOAP que:
- Serializa os parâmetros do serviço para XML;
- Chama o método da web por meio da manipulação de HTTP; e
- Analise a resposta XML de retorno em um objeto.
Sobre a primeira abordagem (usando wsimport
):
Vejo que você já tem as classes de negócios de serviços (entidades ou outras), e é um fato que o wsimport
gera um novo conjunto de classes (que são de alguma forma duplicatas das classes que você já tem).
Infelizmente, neste cenário, você só pode:
- Adapte (edite) o
wsimport
código gerado para que ele use suas classes de negócios (isso é difícil e de alguma forma não vale a pena - tenha em mente que toda vez que o WSDL mudar, você terá que regenerar e readaptar o código); ou
- Desista e use as
wsimport
classes geradas. (Nesta solução, seu código de negócios poderia "usar" as classes geradas como um serviço de outra camada de arquitetura.)
Sobre a segunda abordagem (crie seu cliente SOAP personalizado):
Para implementar a segunda abordagem, você terá que:
- Faça a chamada:
- Use a estrutura SAAJ (SOAP com API de anexos para Java) (veja abaixo, é fornecido com Java SE 1.6 ou superior) para fazer as chamadas; ou
- Você também pode fazer isso por meio
java.net.HttpUrlconnection
(e algum java.io
manuseio).
- Transforme os objetos em XML e vice-versa:
- Use uma estrutura OXM (Object to XML Mapping), como JAXB, para serializar / desserializar o XML de / para objetos
- Ou, se necessário, crie / analise manualmente o XML (esta pode ser a melhor solução se o objeto recebido for apenas um pouco diferente do enviado).
Criar um cliente SOAP usando o clássico java.net.HttpUrlConnection
não é tão difícil (mas também não é tão simples), e você pode encontrar neste link um código inicial muito bom.
Eu recomendo que você use a estrutura SAAJ:
SOAP com API de anexos para Java (SAAJ) é usado principalmente para lidar diretamente com mensagens de solicitação / resposta SOAP que acontecem nos bastidores em qualquer API de serviço da web. Ele permite que os desenvolvedores enviem e recebam diretamente mensagens soap em vez de usar JAX-WS.
Veja abaixo um exemplo funcional (execute-o!) De uma chamada de serviço da web SOAP usando SAAJ. Ele chama esse serviço da web .
import javax.xml.soap.*;
public class SOAPClientSAAJ {
// SAAJ - SOAP Client Testing
public static void main(String args[]) {
/*
The example below requests from the Web Service at:
https://www.w3schools.com/xml/tempconvert.asmx?op=CelsiusToFahrenheit
To call other WS, change the parameters below, which are:
- the SOAP Endpoint URL (that is, where the service is responding from)
- the SOAP Action
Also change the contents of the method createSoapEnvelope() in this class. It constructs
the inner part of the SOAP envelope that is actually sent.
*/
String soapEndpointUrl = "https://www.w3schools.com/xml/tempconvert.asmx";
String soapAction = "https://www.w3schools.com/xml/CelsiusToFahrenheit";
callSoapWebService(soapEndpointUrl, soapAction);
}
private static void createSoapEnvelope(SOAPMessage soapMessage) throws SOAPException {
SOAPPart soapPart = soapMessage.getSOAPPart();
String myNamespace = "myNamespace";
String myNamespaceURI = "https://www.w3schools.com/xml/";
// SOAP Envelope
SOAPEnvelope envelope = soapPart.getEnvelope();
envelope.addNamespaceDeclaration(myNamespace, myNamespaceURI);
/*
Constructed SOAP Request Message:
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:myNamespace="https://www.w3schools.com/xml/">
<SOAP-ENV:Header/>
<SOAP-ENV:Body>
<myNamespace:CelsiusToFahrenheit>
<myNamespace:Celsius>100</myNamespace:Celsius>
</myNamespace:CelsiusToFahrenheit>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
*/
// SOAP Body
SOAPBody soapBody = envelope.getBody();
SOAPElement soapBodyElem = soapBody.addChildElement("CelsiusToFahrenheit", myNamespace);
SOAPElement soapBodyElem1 = soapBodyElem.addChildElement("Celsius", myNamespace);
soapBodyElem1.addTextNode("100");
}
private static void callSoapWebService(String soapEndpointUrl, String soapAction) {
try {
// Create SOAP Connection
SOAPConnectionFactory soapConnectionFactory = SOAPConnectionFactory.newInstance();
SOAPConnection soapConnection = soapConnectionFactory.createConnection();
// Send SOAP Message to SOAP Server
SOAPMessage soapResponse = soapConnection.call(createSOAPRequest(soapAction), soapEndpointUrl);
// Print the SOAP Response
System.out.println("Response SOAP Message:");
soapResponse.writeTo(System.out);
System.out.println();
soapConnection.close();
} catch (Exception e) {
System.err.println("\nError occurred while sending SOAP Request to Server!\nMake sure you have the correct endpoint URL and SOAPAction!\n");
e.printStackTrace();
}
}
private static SOAPMessage createSOAPRequest(String soapAction) throws Exception {
MessageFactory messageFactory = MessageFactory.newInstance();
SOAPMessage soapMessage = messageFactory.createMessage();
createSoapEnvelope(soapMessage);
MimeHeaders headers = soapMessage.getMimeHeaders();
headers.addHeader("SOAPAction", soapAction);
soapMessage.saveChanges();
/* Print the request message, just for debugging purposes */
System.out.println("Request SOAP Message:");
soapMessage.writeTo(System.out);
System.out.println("\n");
return soapMessage;
}
}
Sobre o uso de JAXB para serializar / desserializar, é muito fácil encontrar informações sobre ele. Você pode começar aqui: http://www.mkyong.com/java/jaxb-hello-world-example/ .