私はSpring 3.1.4を使用しています
コントローラ クラス
package com.demo.scheduler.controller;
import java.util.Map;
import com.demo.scheduler.service.SchedulerService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
@Controller
public class SchedulerController {
private SchedulerService service;
@Autowired
public SchedulerController(SchedulerService service) {
this.service = service;
}
@RequestMapping(value = "/tasklist",method = RequestMethod.GET)
public String listTask(Map<String, Object> model) {
model.put("task", service.getTask());
return "tasklist";
}
}
サービスの実装
package com.demo.scheduler.service;
import com.demo.scheduler.TaskConfig;
@Service
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public class SchedulerServiceImpl implements SchedulerService {
@Autowired
public SchedulerDAO schedulerDAO;
@Override
@Transactional(propagation = Propagation.REQUIRED, readOnly = false)
public List<TaskConfig> getTask() {
return schedulerDAO.getTask();
}
}
DAO の実装
package com.demo.scheduler.dao;
import com.demo.scheduler.TaskConfig;
import java.util.List;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
@Repository
public class HibernateDAO implements SchedulerDAO {
@Autowired
private SessionFactory sessionFactory;
public HibernateDAO(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
@SuppressWarnings("unchecked")
@Override
public List<TaskConfig> getTask() {
return sessionFactory.getCurrentSession().createCriteria(
TaskConfig.class).list();
}
}
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_ID" version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<display-name>demoscheduler</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
<servlet>
<servlet-name>demo</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet
</servlet-class></servlet>
<servlet-mapping>
<servlet-name>demo</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping><session-config>
<session-timeout>60</session-timeout>
</session-config>
</web-app>
demo-servlet.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">
<context:component-scan base-package="com.demo.scheduler" />
<context:annotation-config />
<tx:annotation-driven />
<bean id="jspViewResolver"
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass"
value="org.springframework.web.servlet.view.JstlView" />
<property name="prefix" value="/WEB-INF/jsp/" />
<property name="suffix" value=".jsp" />
</bean>
<bean id="propertyConfigurer"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="location">
<value>/WEB-INF/resources/hibernate.properties
</value>
</property>
</bean>
<bean class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"
id="sessionFactory">
<property name="dataSource" ref="dataSource">
</property>
<property name="configLocations">
<list>
<value>/WEB-INF/resources/schedulerTask.hbm.xml
</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">${hibernate.dialect}</prop>
<prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
<prop key="hibernate.format_sql">${hibernate.format_sql}</prop>
<prop key="hibernate.connection.provider_class">${hibernate.connection.provider_class}
</prop>
<prop key="hibernate.c3p0.acquire_increment">${hibernate.c3p0.acquire_increment}
</prop>
<prop key="hibernate.c3p0.idle_test_period">${hibernate.c3p0.idle_test_period}
</prop>
<prop key="hibernate.c3p0.max_size">${hibernate.c3p0.max_size}
</prop>
<prop key="hibernate.c3p0.max_statements">${hibernate.c3p0.max_statements}
</prop>
<prop key="hibernate.c3p0.min_size">${hibernate.c3p0.min_size}
</prop>
<prop key="hibernate.c3p0.timeout">${hibernate.c3p0.timeout}
</prop>
</props>
</property>
</bean>
<bean class="org.springframework.jdbc.datasource.DriverManagerDataSource"
id="dataSource">
<property name="driverClassName" value="${hibernate.connection.driver_class}" />
<property name="url" value="${hibernate.connection.url}" />
<property name="username" value="${hibernate.connection.username}" />
<property name="password" value="${hibernate.connection.password}" />
</bean>
<bean id="transactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
</beans>
コードを更新した後、次のエラーが発生しました。
9544 [http-4186-2] エラー org.springframework.web.servlet.DispatcherServlet - コンテキストの初期化に失敗しました ネストされた例外は org.springframework.beans.factory.BeanCreationException: Could not autowire field: private com.demo.scheduler.service.SchedulerService com.demo.scheduler.controller.SchedulerController.service; です。入れ子になった例外は org.springframework.beans.factory.BeanCreationException: 'schedulerServiceImpl' という名前の Bean の作成中にエラーが発生しました: 自動配線された依存関係の注入に失敗しました。ネストされた例外は org.springframework.beans.factory.BeanCreationException: Could not autowire field: public com.demo.scheduler.dao.SchedulerDAO com.demo.scheduler です。service.SchedulerServiceImpl.schedulerDAO; ネストされた例外は org.springframework.beans.factory.BeanCreationException: 'hibernateDAO' という名前の Bean の作成中にエラーが発生しました: 自動配線された依存関係の注入に失敗しました。ネストされた例外は org.springframework.beans.factory.BeanCreationException: Could not autowire field: private org.hibernate.SessionFactory com.demo.scheduler.dao.HibernateDAO.sessionFactory; です。ネストされた例外は org.springframework.beans.factory.BeanCreationException: ServletContext リソース [/WEB-INF/applicationContext.xml] で定義された名前 'sessionFactory' を持つ Bean の作成中にエラーが発生しました: init メソッドの呼び出しに失敗しました。ネストされた例外は、org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor の java.lang.NullPointerException です。ErrorReportValve.invoke(ErrorReportValve.java:102) org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:263) org .apache.coyote.http11.Http11Processor.process(Http11Processor.java:844) at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:584) at org.apache.tomcat.util.net.JIoEndpoint java.lang.Thread.run(Thread.java:662) の $Worker.run(JIoEndpoint.java:447) 原因: org.springframework.beans.factory.BeanCreationException: フィールドを自動配線できませんでした: プライベート com.demo.scheduler .service.SchedulerService com.demo.scheduler.controller.SchedulerController.service; ネストされた例外は org.springframework.beans.factory.BeanCreationException: 「schedulerServiceImpl」という名前の Bean の作成中にエラーが発生しました: 自動配線された依存関係の注入に失敗しました。ネストされた例外は org.springframework.beans.factory.BeanCreationException: Could not autowire field: public com.demo.scheduler.dao.SchedulerDAO com.demo.scheduler.service.SchedulerServiceImpl.schedulerDAO; です。ネストされた例外は org.springframework.beans.factory.BeanCreationException: 'hibernateDAO' という名前の Bean の作成中にエラーが発生しました: 自動配線された依存関係の注入に失敗しました。ネストされた例外は org.springframework.beans.factory.BeanCreationException: Could not autowire field: private org.hibernate.SessionFactory com.demo.scheduler.dao.HibernateDAO.sessionFactory; です。ネストされた例外は org.springframework.beans.factory.BeanCreationException: 'sessionFactory' という名前の Bean の作成中にエラーが発生しました ServletContext リソース [/WEB-INF/applicationContext.xml] で定義: init メソッドの呼び出しに失敗しました。ネストされた例外は、org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:513) の java.lang.NullPointerException です。org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java: 92) org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessPropertyValues(AutowiredAnnotationBeanPostProcessor.java:284) で ... 29 その他自動配線された依存関係の注入に失敗しました。ネストされた例外は org.springframework.beans.factory です。BeanCreationException: フィールドを自動配線できませんでした: public com.demo.scheduler.dao.SchedulerDAO com.demo.scheduler.service.SchedulerServiceImpl.schedulerDAO; ネストされた例外は org.springframework.beans.factory.BeanCreationException: 'hibernateDAO' という名前の Bean の作成中にエラーが発生しました: 自動配線された依存関係の注入に失敗しました。ネストされた例外は org.springframework.beans.factory.BeanCreationException: Could not autowire field: private org.hibernate.SessionFactory com.demo.scheduler.dao.HibernateDAO.sessionFactory; です。ネストされた例外は org.springframework.beans.factory.BeanCreationException: ServletContext リソース [/WEB-INF/applicationContext.xml] で定義された名前 'sessionFactory' を持つ Bean の作成中にエラーが発生しました: init メソッドの呼び出しに失敗しました。ネストされた例外は、org.springframework の java.lang.NullPointerException です。AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:485) ... 31 以上 原因: org.springframework.beans.factory.BeanCreationException: フィールドを自動配線できませんでした: public com.demo.scheduler.dao.SchedulerDAO com.demo.scheduler .service.SchedulerServiceImpl.schedulerDAO; ネストされた例外は org.springframework.beans.factory.BeanCreationException: 'hibernateDAO' という名前の Bean の作成中にエラーが発生しました: 自動配線された依存関係の注入に失敗しました。ネストされた例外は org.springframework.beans.factory.BeanCreationException: Could not autowire field: private org.hibernate.SessionFactory com.demo.scheduler.dao.HibernateDAO.sessionFactory; です。ネストされた例外は org.springframework.beans.factory.BeanCreationException: 'sessionFactory' という名前の Bean の作成中にエラーが発生しました ServletContext リソース [/WEB-INF/applicationContext.xml] で定義: init メソッドの呼び出しに失敗しました。ネストされた例外は、org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:513) の java.lang.NullPointerException です。org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java: 92) org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessPropertyValues(AutowiredAnnotationBeanPostProcessor.java:284) で ... 44 以上自動配線された依存関係の注入に失敗しました。ネストされた例外は org.springframework.beans.factory です。BeanCreationException: フィールドを自動配線できませんでした: プライベート org.hibernate.SessionFactory com.demo.scheduler.dao.HibernateDAO.sessionFactory; ネストされた例外は org.springframework.beans.factory.BeanCreationException: ServletContext リソース [/WEB-INF/applicationContext.xml] で定義された名前 'sessionFactory' を持つ Bean の作成中にエラーが発生しました: init メソッドの呼び出しに失敗しました。ネストされた例外は、org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1106) の org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessPropertyValues(AutowiredAnnotationBeanPostProcessor.java:287) の java.lang.NullPointerException です。 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory で。org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:730) の DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:813) org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor. java:485) ... 46 以上 原因: org.springframework.beans.factory.BeanCreationException: フィールドを自動配線できませんでした: プライベート org.hibernate.SessionFactory com.demo.scheduler.dao.HibernateDAO.sessionFactory; ネストされた例外は org.springframework.beans.factory.BeanCreationException: ServletContext リソース [/WEB-INF/applicationContext.xml] で定義された名前 'sessionFactory' を持つ Bean の作成中にエラーが発生しました: init メソッドの呼び出しに失敗しました。ネストされた例外は java. lang.NullPointerException at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:513) at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:92) at org. springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessPropertyValues(AutowiredAnnotationBeanPostProcessor.java:284) ... 57 より多くの原因: org.springframework.beans.factory.BeanCreationException: ServletContext リソースで定義された名前「sessionFactory」の Bean 作成エラー [/ WEB-INF/applicationContext.xml]: init メソッドの呼び出しに失敗しました。ネストされた例外は、org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory の java.lang.NullPointerException です。