봄 부트 프로젝트는 기존 SOAP 웹 서비스를 호출하는 방법은, 스프링 부팅 스타터 웹 서비스의 단지 소개 매우 간단합니다.
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web-services</artifactId>
</dependency>
WebServiceTemplate
우리는 WebServiceTemplate SOAP 서비스를 호출하는 데 사용. WebServiceTemplate 통화 방법 sendSourceAndReceive, marshalSendAndReceive, sendAndReceive의 세 가지 유형을 제공합니다. 개체에 비해 marshalSendAndReceive 송신 방법, 수신 결과를 자동 변환하는 Marshaller Unmarshaller에 의해 구성; sendAndReceive 지원 하위 작업 전송하고 XML 메시지를 수신 sendSourceAndReceive 직접적인 방법.
package org.iata.caims.service.ws;
import org.springframework.boot.webservices.client.WebServiceTemplateBuilder;
import org.springframework.stereotype.Service;
import org.springframework.ws.client.core.WebServiceTemplate;
import javax.xml.transform.stream.StreamResult;
import javax.xml.transform.stream.StreamSource;
import java.io.StringReader;
@Service
public class MyService {
private static final String DEFAULT_URI = "http://localhost:8080/HelloService";
private static final String MESSAGE = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" +
"<ns1:sayHello xmlns:ns1=\"http://webservice.itrunner.org\">\n" +
" <ns1:in0>COCO</ns1:in0>\n" +
"</ns1:sayHello>";
private final WebServiceTemplate webServiceTemplate;
public MyService(WebServiceTemplateBuilder webServiceTemplateBuilder) {
this.webServiceTemplate = webServiceTemplateBuilder.setDefaultUri(DEFAULT_URI).build();
}
public void sendSourceAndReceive() {
StreamSource source = new StreamSource(new StringReader(MESSAGE));
StreamResult result = new StreamResult(System.out);
webServiceTemplate.sendSourceAndReceiveToResult(source, result);
}
public Object marshalSendAndReceive(String uri, Object requestPayload) {
return this.webServiceTemplate.marshalSendAndReceive(uri, requestPayload);
}
}
marshalSendAndReceive 일반적 방법을 사용한다. 웹 서비스는 방법과 매개 변수를 지원을 위해 당신은 당신이 사용할 수있는, WSDL 파일을 읽고 배울 수 SoapUI의 요청, 응답 XML, SOAP 도메인 객체를 생성하는 도구를 다음 손으로 쓰기. 간단한 방법은 자동으로 생성 받는다는-JAXB2 - 플러그인 위젯을 사용하는 것입니다.
받는다는 - JAXB2 - 플러그인
<plugin>
<groupId>org.jvnet.jaxb2.maven2</groupId>
<artifactId>maven-jaxb2-plugin</artifactId>
<version>0.14.0</version>
<executions>
<execution>
<goals>
<goal>generate</goal>
</goals>
</execution>
</executions>
<configuration>
<generatePackage>org.itrunner.ws</generatePackage>
<generateDirectory>${project.basedir}/src/main/java</generateDirectory>
<schemaDirectory>${project.basedir}/src/main/resources/wsdl</schemaDirectory>
<schemaIncludes>
<include>*.wsdl</include>
</schemaIncludes>
</configuration>
</plugin>
구성으로, 자원 / WSDL 폴더에 WSDL 파일은 컴파일 시간 package-info.java, ObjectFactory를, 요청, 응답을 포함하여 지정된 패키지 받는다는 스텁 클래스를 관련된 모든 웹 서비스 메소드를 생성하고 XML을 구성되었습니다 참고.
package-info.java
@javax.xml.bind.annotation.XmlSchema(namespace = "http://webservice.itrunner.org", elementFormDefault = javax.xml.bind.annotation.XmlNsForm.QUALIFIED)
package org.iata.caims.service.test;
ObjectFactory를
import javax.xml.bind.annotation.XmlRegistry;
@XmlRegistry
public class ObjectFactory {
/**
* Create a new ObjectFactory that can be used to create new instances of schema derived classes for package: org.itrunner.ws
*/
public ObjectFactory() {
}
/**
* Create an instance of {@link SayHello }
*/
public SayHello createSayHello() {
return new SayHello();
}
/**
* Create an instance of {@link SayHelloResponse }
*/
public SayHelloResponse createSayHelloResponse() {
return new SayHelloResponse();
}
}
요청
웹 서비스 메소드 이름에 해당하는 요청 클래스 이름은 웹 서비스 매개 변수에 해당하는 속성.
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlType;
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "", propOrder = {
"in0"
})
@XmlRootElement(name = "sayHello")
public class SayHello {
@XmlElement(required = true, nillable = true)
protected String in0;
/**
* Gets the value of the in0 property.
*
* @return possible object is {@link String }
*/
public String getIn0() {
return in0;
}
/**
* Sets the value of the in0 property.
*
* @param value allowed object is {@link String }
*/
public void setIn0(String value) {
this.in0 = value;
}
}
응답
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlType;
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "", propOrder = {
"out"
})
@XmlRootElement(name = "sayHelloResponse")
public class SayHelloResponse {
@XmlElement(required = true, nillable = true)
protected String out;
/**
* Gets the value of the out property.
*
* @return possible object is {@link String }
*/
public String getOut() {
return out;
}
/**
* Sets the value of the out property.
*
* @param value allowed object is {@link String }
*/
public void setOut(String value) {
this.out = value;
}
}
헬기 소규모
WebServiceTemplateBuilde 및 Jaxb2Marshaller 구성 :
import org.springframework.boot.webservices.client.HttpWebServiceMessageSenderBuilder;
import org.springframework.boot.webservices.client.WebServiceTemplateBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.oxm.jaxb.Jaxb2Marshaller;
import org.springframework.ws.client.core.WebServiceTemplate;
import static java.time.Duration.ofSeconds;
@Configuration
public class Config {
@Bean
public WebServiceTemplate webServiceTemplate(WebServiceTemplateBuilder builder) {
return builder.messageSenders(new HttpWebServiceMessageSenderBuilder().setConnectTimeout(ofSeconds(60)).setReadTimeout(ofSeconds(60)).build()).build();
}
@Bean
public Jaxb2Marshaller jaxb2Marshaller() {
Jaxb2Marshaller marshaller = new Jaxb2Marshaller();
marshaller.setContextPath("org.itrunner.ws");
return marshaller;
}
}
웹 서비스를 호출 :
import org.springframework.boot.webservices.client.WebServiceTemplateBuilder;
import org.springframework.oxm.jaxb.Jaxb2Marshaller;
import org.springframework.stereotype.Service;
import org.springframework.ws.client.core.WebServiceTemplate;
@Service
public class HelloService {
private static final String DEFAULT_URI = "http://localhost:8080/HelloService";
private final WebServiceTemplate webServiceTemplate;
public HelloService(WebServiceTemplateBuilder webServiceTemplateBuilder, Jaxb2Marshaller jaxb2Marshaller) {
this.webServiceTemplate = webServiceTemplateBuilder.setDefaultUri(DEFAULT_URI)
.setMarshaller(jaxb2Marshaller).setUnmarshaller(jaxb2Marshaller).build();
}
public SayHelloResponse sayHello(SayHello request) {
return (SayHelloResponse) this.webServiceTemplate.marshalSendAndReceive(request);
}
}