Почему я могу автоматически подключить или ввести Pojo, но я не могу автоматически подключить или ввести RestTemplate
Я много читал на этом форуме о похожих проблемах, возникающих при попытке AutoWire Pojo, и обычно ответ исправитьcomponent-scan
или же@Component
/@Controller
, Но в моем случае мне удается автоматически подключить мой Pojo (Mas60010), но я не могу автоматически подключитьRestTemplate
или жеObjectMapper
и, возможно, любой другой объект из пакета, который я не кодировал.
Проще говоря, я просто упоминаюRestTemplate
, Что я делаю не так? Я думаю, что проблема либо с библиотеками, либо с конфигурацией. Примечание: пожалуйста, не указывайте этот вопрос как дубликат, только показывая вопрос, связанный с его собственным pojo. Вы можете видеть, что это не мой вопрос, потому что я могу справиться с этим. Проблема в том, что классы внутри jar включены в мой проект.
package com.ma.mhe.log.handler;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.web.client.RestTemplate;
@Component
public class Lo_DisplayHandler extends Lo_Handler {
@Autowired private Mas60010 _mas60010; //this work perfectly
@Autowired private RestTemplate restTemplate; //this always cause nullPointException
MVC-диспетчерская-servlet.xml
<context:annotation-config />
<mvc:annotation-driven />
<context:component-scan base-package="com.ma.mhe.log.handle, com.ma.mhe.log.domain" />
<context:property-placeholder location="classpath:restServices.properties"/>
<mvc:resources mapping="/**" location="/" />
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix">
<value>/WEB-INF/pages/</value>
</property>
<property name="suffix">
<value>.jsp</value>
</property>
</bean>
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">
<property name="messageConverters">
<list>
<ref bean="jsonMessageConverter"/>
</list>
</property>
</bean>
<bean id="jsonMessageConverter" class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
</bean>
<!-- I was expecting this line to be enouth -->
<bean id="restTemplate" class="org.springframework.web.client.RestTemplate">
</bean>
// Pojo - я могу подключить его
package com.ma.log.domain;
import org.springframework.stereotype.Service;
@Service
public class Mas60010 {
Все библиотеки
"Проверка-апи-1.0.0.GA.jar""Aopalliance-1.0.jar""Обще-каротаж 1.1.1.jar""Db2java.zip""Зимуют-валидатор-4.1.0.Final.jar""Зимуют-валидатор-аннотаций-процессор 4.1.0.Final.jar""Джэксона-аннотаций-2.2.3.jar""Джексон-ядро-2.2.3.jar""Джексон-DataBind-2.2.3.jar""SLF4J-апи-1.7.5.jar""Весна-АОП-4.1.2.RELEASE.jar""Весна-бобы-4.1.2.RELEASE.jar""Весна-контекст-4.1.2.RELEASE.jar""Весна-контекст-поддержка-4.1.2.RELEASE.jar""Весна-ядро-4.1.2.RELEASE.jar""Весна-выражение-4.1.2.RELEASE.jar""Весна-веб-4.1.2.RELEASE.jar""Весна-webmvc-4.1.2.RELEASE.jar""Upload.jar"//Трассировки стека
[12/17/14 10:38:54:243 CST] 00000033 SystemErr R at com.ma.mhe.log.handler.Lo_DisplayHandler.lastPage(Lo_DisplayHandler.java:181)
[12/17/14 10:38:54:246 CST] 00000033 SystemErr R at com.ma.mhe.log.Lo_Servlet.doDisDis(Lo_Servlet.java:164)
[12/17/14 10:38:54:248 CST] 00000033 SystemErr R at com.ma.mhe.log.Lo_Servlet.doProcess(Lo_Servlet.java:51)
[12/17/14 10:38:54:250 CST] 00000033 SystemErr R at com.ma.mhe.log.Lo_Servlet.doPost(Lo_Servlet.java:24)
[12/17/14 10:38:54:253 CST] 00000033 SystemErr R at javax.servlet.http.HttpServlet.service(HttpServlet.java:595)
[12/17/14 10:38:54:255 CST] 00000033 SystemErr R at javax.servlet.http.HttpServlet.service(HttpServlet.java:668)
[12/17/14 10:38:54:257 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.servlet.ServletWrapper.service(ServletWrapper.java:1274)
[12/17/14 10:38:54:260 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:767)
[12/17/14 10:38:54:261 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:469)
[12/17/14 10:38:54:262 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.filter.WebAppFilterManager.invokeFilters(WebAppFilterManager.java:1060)
[12/17/14 10:38:54:263 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.webapp.WebAppRequestDispatcher.dispatch(WebAppRequestDispatcher.java:1377)
[12/17/14 10:38:54:265 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.webapp.WebAppRequestDispatcher.forward(WebAppRequestDispatcher.java:185)
[12/17/14 10:38:54:266 CST] 00000033 SystemErr R at com.ma.mhe.Mhe_ControllerServlet.doProcess(Mhe_ControllerServlet.java:83)
[12/17/14 10:38:54:267 CST] 00000033 SystemErr R at com.ma.mhe.Mhe_ControllerServlet.doPost(Mhe_ControllerServlet.java:32)
[12/17/14 10:38:54:268 CST] 00000033 SystemErr R at javax.servlet.http.HttpServlet.service(HttpServlet.java:595)
[12/17/14 10:38:54:269 CST] 00000033 SystemErr R at javax.servlet.http.HttpServlet.service(HttpServlet.java:668)
[12/17/14 10:38:54:270 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.servlet.ServletWrapper.service(ServletWrapper.java:1274)
[12/17/14 10:38:54:271 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:767)
[12/17/14 10:38:54:272 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:469)
[12/17/14 10:38:54:273 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.filter.WebAppFilterManager.invokeFilters(WebAppFilterManager.java:1060)
[12/17/14 10:38:54:275 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.servlet.CacheServletWrapper.handleRequest(CacheServletWrapper.java:81)
[12/17/14 10:38:54:276 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.WebContainer.handleRequest(WebContainer.java:885)
[12/17/14 10:38:54:277 CST] 00000033 SystemErr R at com.ibm.ws.webcontainer.osgi.DynamicVirtualHost$2.run(DynamicVirtualHost.java:266)
[12/17/14 10:38:54:277 CST] 00000033 SystemErr R at com.ibm.ws.http.dispatcher.internal.channel.HttpDispatcherLink$TaskWrapper.run(HttpDispatcherLink.java:776)
[12/17/14 10:38:54:278 CST] 00000033 SystemErr R at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895)
[12/17/14 10:38:54:279 CST] 00000033 SystemErr R at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918)
[12/17/14 10:38:54:280 CST] 00000033 SystemErr R at java.lang.Thread.run(Thread.java:662)
IBM WebSphere Liberty Profile включенные функции
<featureManager>
<feature>jsp-2.2</feature>
<feature>localConnector-1.0</feature>
<feature>jdbc-4.0</feature>
<feature>jaxrs-1.1</feature>
<feature>json-1.0</feature>
<feature>cdi-1.0</feature>
<feature>managedBeans-1.0</feature>
<feature>beanValidation-1.0</feature>
</featureManager>
// класс Lo_DisplayHandler
@Component
public class Lo_DisplayHandler extends Lo_Handler {
public Lo_DisplayHandler() {
super();
}
@Autowired
private Mas60010 _mas60010;
@Autowired private RestTemplate restTemplate;
public Lo_DisplayHandler(HttpServletRequest request,HttpServletResponse response) {
super();
this.request = request;
this.response = response;
}
public void lastPage() {
//RestTemplate restTemplate = new RestTemplate(); //if I uncomment this line and comment the @Autowired it will work
ObjectMapper mapper = new ObjectMapper();
try{
myPojoParameters...
//the next line rises nullPointExcepetion if I choose Autowired instead of new RestTemplate()
LogDisplay _l = restTemplate.postForObject(myServiceUrl,myPojoParameters, LogDisplay.class);
Lo_DisplayRecord lo_DisplayRecord = new Lo_DisplayRecord();
ArrayList<Lo_DisplayRecord> displayValues = new ArrayList<Lo_DisplayRecord>();
for(int i = 0; i < _l.getDisplayValues().size(); i++){
lo_DisplayRecord = mapper.convertValue(_l.getDisplayValues().get(i), Lo_DisplayRecord.class);
displayValues.add(lo_DisplayRecord);
}
Some not relevant operations...
}catch(Exception e){
e.printStackTrace();
// Lo_Servlet
package com.ma.mhe.log;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import com.ma.mhe.Mhe_Servlet;
import com.ma.mhe.PageFlow;
import com.ma.mhe.log.handler.*;
public class Lo_Servlet extends Mhe_Servlet {
private String _module = "lo public void init(){}
public void doPost(
javax.servlet.http.HttpServletRequest request,
javax.servlet.http.HttpServletResponse response)
throws javax.servlet.ServletException, java.io.IOException {
doProcess(request,response);
}
public void doGet(
javax.servlet.http.HttpServletRequest request,
javax.servlet.http.HttpServletResponse response)
throws javax.servlet.ServletException, java.io.IOException {
doProcess(request,response);
}
public void doProcess(
javax.servlet.http.HttpServletRequest request,
javax.servlet.http.HttpServletResponse response)
throws javax.servlet.ServletException, java.io.IOException {
HttpSession session = request.getSession();
int val = setTask(session,request);
switch(val){
//FILTER PAGE
case 1:doFilRep(request,response);break;
case 2:doFilFil(request,response);break;
case 3:doFilDis(request,response);break;
case 4:doFilDef(request,response);break;
//DISPLAY PAGE
case 5:doDisRep(request,response);break;
case 6:doDisFil(request,response);break;
case 7:doDisDis(request,response);break;
private void doDisDis(HttpServletRequest request,HttpServletResponse response){
Lo_DisplayHandler display = null;
try{
display = new Lo_DisplayHandler(request,response);
display.lastPage();
}catch(Exception e){
}finally{
display = null;
}
}
//web.xml http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd "> MHE
<servlet>
<servlet-name>mvc-dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>mvc-dispatcher</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<servlet>
<servlet-name>myservice</servlet-name>
<servlet-class>org.springframework.ws.transport.http.MessageDispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/mvc-dispatcher-servlet.xml</param-value>
</init-param>
</servlet>
<servlet>
<description>
</description>
<display-name>Lo_Servlet</display-name>
<servlet-name>Lo_Servlet</servlet-name>
<servlet-class>com.ma.mhe.log.Lo_Servlet</servlet-class>
</servlet>
... others servlets configuration like this