Spring-boot在创建自定义RestTemplate时出错
Spring-boot gets an error when creating custom RestTemplate
我有一个 sendGetREST
方法来发送一些 URL endpoint
并得到响应:
@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;
}
}
}
效果很好。但是,为了使超时时间可自定义,我从这个 tutorial:
得到了这个 HTTPConfiguration
@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;
}
}
因此 class 将像这样调用 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;
}
}
}
但不幸的是 return 在构建 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$1f99f.CGLIB$restTemplate[=14=](<generated>) ~[na:na]
at com.xl.MbbI.config.HTTPConfiguration$$EnhancerBySpringCGLIB$1f99f$$FastClassBySpringCGLIB$30ce57.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$1f99f.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.run(Unknown Source) ~[na:1.7.0_60]
at java.net.URLClassLoader.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
错误显示您的class路径有问题,可能是因为您的class路径中没有class or.apache.http.protocol.HttpContext。这个class经常被SpringRestTemplate使用。通常我们可以在 Apache httpclient 库中找到这个 class。您应该再次检查您的依赖项。如果找不到,可以考虑添加下面的依赖(如果你使用Maven)
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.2</version>
</dependency>
我有一个 sendGetREST
方法来发送一些 URL endpoint
并得到响应:
@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;
}
}
}
效果很好。但是,为了使超时时间可自定义,我从这个 tutorial:
得到了这个HTTPConfiguration
@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;
}
}
因此 class 将像这样调用 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;
}
}
}
但不幸的是 return 在构建 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$1f99f.CGLIB$restTemplate[=14=](<generated>) ~[na:na]
at com.xl.MbbI.config.HTTPConfiguration$$EnhancerBySpringCGLIB$1f99f$$FastClassBySpringCGLIB$30ce57.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$1f99f.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.run(Unknown Source) ~[na:1.7.0_60]
at java.net.URLClassLoader.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
错误显示您的class路径有问题,可能是因为您的class路径中没有class or.apache.http.protocol.HttpContext。这个class经常被SpringRestTemplate使用。通常我们可以在 Apache httpclient 库中找到这个 class。您应该再次检查您的依赖项。如果找不到,可以考虑添加下面的依赖(如果你使用Maven)
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.2</version>
</dependency>