カスタムRestTemplateを作成すると、スプリングブートでエラーが発生する
いくつかのURL endpoint
を送信して応答を受け取るsendGetREST
メソッドがあります。
@Component
public class HttpURLCommand {
private static Logger logger = Logger.getLogger(HttpURLCommand.class);
public String sendGetREST(String soapUrl, Object[] parameters) throws IOException{
final String SOAP_URL = MessageFormat.format(soapUrl, parameters);
RestTemplate restTemplate = new RestTemplate();
ResponseEntity<String> response = restTemplate.getForEntity(SOAP_URL, String.class);
logger.info("status code is: "+response.getStatusCode());
if(response.getStatusCode().equals(HttpStatus.OK)){
logger.info("send success");
return response.getBody();
}
else {
logger.info("send failed");
return null;
}
}
}
うまくいきます。ただし、タイムアウト時間をカスタマイズ可能にするために、これからHTTPConfiguration
を取得しました tutorial :
@Configuration
public class HTTPConfiguration {
@Bean
public RestTemplate restTemplate() {
return new RestTemplate(clientHttpRequestFactory());
}
private ClientHttpRequestFactory clientHttpRequestFactory() {
HttpComponentsClientHttpRequestFactory factory = new HttpComponentsClientHttpRequestFactory();
factory.setReadTimeout(60000);
factory.setConnectTimeout(60000);
return factory;
}
}
したがって、クラスは次のようにrestTemplateを呼び出します:
@Component
public class HttpURLCommand {
private static Logger logger = Logger.getLogger(HttpURLCommand.class);
@Autowired
RestTemplate restTemplate;
public String sendGetREST(String soapUrl, Object[] parameters) throws IOException{
final String SOAP_URL = MessageFormat.format(soapUrl, parameters);
ResponseEntity<String> response = restTemplate.getForEntity(SOAP_URL, String.class);
logger.info("status code is: "+response.getStatusCode());
if(response.getStatusCode().equals(HttpStatus.OK)){
logger.info("send success");
return response.getBody();
}
else {
logger.info("send failed");
return null;
}
}
}
ただし、spring-boot
アプリをビルドすると、残念ながら次のエラーが返されます。
Caused by: Java.lang.NoClassDefFoundError: org/Apache/http/protocol/HttpContext
at com.xl.MbbI.config.HTTPConfiguration.clientHttpRequestFactory(HTTPConfiguration.Java:25) ~[classes/:na]
at com.xl.MbbI.config.HTTPConfiguration.restTemplate(HTTPConfiguration.Java:21) ~[classes/:na]
at com.xl.MbbI.config.HTTPConfiguration$$EnhancerBySpringCGLIB$$191f99f.CGLIB$restTemplate$0(<generated>) ~[na:na]
at com.xl.MbbI.config.HTTPConfiguration$$EnhancerBySpringCGLIB$$191f99f$$FastClassBySpringCGLIB$$8330ce57.invoke(<generated>) ~[na:na]
at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.Java:228) ~[spring-core-4.3.0.RC2.jar:4.3.0.RC2]
at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.Java:356) ~[spring-context-4.3.0.RC2.jar:4.3.0.RC2]
at com.xl.MbbI.config.HTTPConfiguration$$EnhancerBySpringCGLIB$$191f99f.restTemplate(<generated>) ~[na:na]
at Sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.7.0_60]
at Sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) ~[na:1.7.0_60]
at Sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) ~[na:1.7.0_60]
at Java.lang.reflect.Method.invoke(Unknown Source) ~[na:1.7.0_60]
at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.Java:162) ~[spring-beans-4.3.0.RC2.jar:4.3.0.RC2]
... 24 common frames omitted
Caused by: Java.lang.ClassNotFoundException: org.Apache.http.protocol.HttpContext
at Java.net.URLClassLoader$1.run(Unknown Source) ~[na:1.7.0_60]
at Java.net.URLClassLoader$1.run(Unknown Source) ~[na:1.7.0_60]
at Java.security.AccessController.doPrivileged(Native Method) ~[na:1.7.0_60]
at Java.net.URLClassLoader.findClass(Unknown Source) ~[na:1.7.0_60]
at Java.lang.ClassLoader.loadClass(Unknown Source) ~[na:1.7.0_60]
at Sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source) ~[na:1.7.0_60]
at Java.lang.ClassLoader.loadClass(Unknown Source) ~[na:1.7.0_60]
... 36 common frames omitted
参考までに、エラーは上記に表示されているものよりはるかに多くなっています。
最初の行は次のようなものです:
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'restTemplate' defined in class path resource .....
Caused by: Java.lang.NoClassDefFoundError: org/Apache/http/protocol/HttpContext
このエラーは、クラスパスに問題があったことを示しています。クラスパスにクラスまたは.Apache.http.protocol.HttpContextが存在しないことが原因である可能性があります。このクラスは、Spring RestTemplateでよく使用されます。通常、このクラスはApache httpclientライブラリにあります。依存関係をもう一度確認する必要があります。それが見つからない場合は、以下の依存関係を追加することを検討できます(Mavenを使用している場合)
<dependency>
<groupId>org.Apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.2</version>
</dependency>