私は今行き詰まった。
最初に、コンソールから実行し、注釈ベースの構成である Java アプリケーションを作成しました。
コンソールから実行すると、以下の設定が機能する 設定が config パッケージにある
@Configuration
public class JpaConfiguration {
@Value("#{dataSource}")
private javax.sql.DataSource dataSource;
@Bean
public Map<String, Object> jpaProperties() {
Map<String, Object> props = new HashMap<String, Object>();
props.put("hibernate.dialect", MySQL5Dialect.class.getName());
props.put("javax.persistence.validation.factory", validator());
props.put("hibernate.ejb.naming_strategy", ImprovedNamingStrategy.class.getName());
return props;
}
@Bean
public LocalValidatorFactoryBean validator() {
return new LocalValidatorFactoryBean();
}
@Bean
public JpaVendorAdapter jpaVendorAdapter() {
HibernateJpaVendorAdapter hibernateJpaVendorAdapter = new HibernateJpaVendorAdapter();
hibernateJpaVendorAdapter.setGenerateDdl(true);
hibernateJpaVendorAdapter.setDatabase(Database.MYSQL);
hibernateJpaVendorAdapter.setShowSql(false);
return hibernateJpaVendorAdapter;
}
@Bean
public PlatformTransactionManager transactionManager() {
return new JpaTransactionManager(
localContainerEntityManagerFactoryBean().getObject());
}
@Bean
public LocalContainerEntityManagerFactoryBean localContainerEntityManagerFactoryBean() {
LocalContainerEntityManagerFactoryBean lef = new LocalContainerEntityManagerFactoryBean();
lef.setDataSource(this.dataSource);
lef.setPackagesToScan("domain");
lef.setJpaPropertyMap(this.jpaProperties());
lef.setJpaVendorAdapter(this.jpaVendorAdapter());
return lef;
}
}
@Configuration
@ImportResource("classpath:root-context.xml")
@PropertySource("classpath:database.properties")
public class DataSourceConfig {
public DataSourceConfig() {}
}
これが src/main/resources パッケージにある私の root-context.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:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:jdbc="http://www.springframework.org/schema/jdbc"
xmlns:context="http://www.springframework.org/schema/context" xmlns:p="http://www.springframework.org/schema/p"
xmlns:jpa="http://www.springframework.org/schema/data/jpa"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.1.xsd
http://www.springframework.org/schema/jdbc
http://www.springframework.org/schema/jdbc/spring-jdbc-3.1.xsd
http://www.springframework.org/schema/data/jpa
http://www.springframework.org/schema/data/jpa/spring-jpa.xsd">
<context:property-placeholder location="classpath:database.properties" />
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close"
p:driverClass="com.mysql.jdbc.Driver"
p:jdbcUrl="${jdbc.url}"
p:user="${jdbc.username}"
p:password="${jdbc.password}"
p:initialPoolSize="0"
p:minPoolSize="0"
p:maxPoolSize="10"
p:maxIdleTime="300" />
<jpa:repositories base-package="domain" />
<tx:annotation-driven transaction-manager="transactionManager" />
</beans>
私の主な方法
public class ConsoleRun {
public static void main(String[] args) throws Exception {
final Logger log = LoggerFactory
.getLogger("ConsoleRun");
log.info("Starting application");
AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext();
ctx.scan("*");
ctx.refresh();
TestDao testDao = ctx.getBean(TestDao.class);
testDao.testUsersList();
log.info("========GETTING ALL RESULTS==============");
testDao.testResultsList();
}
}
コンソール パッケージにある DAO にアクセスするための My Service クラス
@Service
public class TestDao {
static final Logger log = LoggerFactory.getLogger("TestDatabase");
@Autowired
private UserDao userDao;
@Autowired
private ResultDao resultDao;
@Autowired
private GameDao gameDao;
public List<User> testUsersList() {
log.info("Getting all users");
List<User> users = userDao.findAll();
for (User u : users) {
log.info("User: {}", u);
}
return users;
}
public void testResultsList() {
List<Result> results = resultDao.findAll();
for (Result r : results) {
log.info("Result: {}", r);
}
}
public User findUserById(Long id) {
return userDao.findById(id);
}
}
上記のコードは、コンソールから起動すると機能します
以下のコードは機能しません
Tomcatコンテナで実行したいときに問題があります。私はそれを構成するためにさまざまな方法を試しています。
JpaConfiguration クラスと root-context.xml を Tomcat に再利用するにはどうすればよいですか?
これは私が現在web.xmlに持っているものです
<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>Restful Web Application</display-name>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/app-config.xml</param-value>
</context-param>
<servlet>
<servlet-name>jersey-serlvet</servlet-name>
<servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>com.sun.jersey.config.property.packages</param-name>
<param-value>api</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>jersey-serlvet</servlet-name>
<url-pattern>/rest/*</url-pattern>
</servlet-mapping>
</web-app>
私の app-config.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:jdbc="http://www.springframework.org/schema/jdbc"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/jdbc
http://www.springframework.org/schema/jdbc/spring-jdbc-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<jpa:repositories base-package="domain" />
<context:component-scan base-package="domain,api,config" />
<!-- Weaves in transactional advice around @Transactional methods -->
<tx:annotation-driven transaction-manager="transactionManager" />
<bean id="dataSource" class="config.DataSourceConfig" />
<bean id="JpaConfiguration" class="config.DataSourceConfig" />
</beans>
userDao が自動配線されず、nullpointer 例外がスローされる主な問題は次のとおりですAuthresource は api パッケージにあります
@Component
@Path("/auth")
public class AuthResource {
@Autowired
UserDao userDao;
@Autowired
TestDao testDao;
@GET
@Path("/users")
@Produces(MediaType.APPLICATION_JSON)
public List<User> getAllUsers() {
return userDao.findAll();
}
}
私の残りは機能しています。URL localhost:8080/application/rest/hello/message で機能する単純な REST サービス クラスがあります。
@Path("/hello")
public class HelloResource {
@GET
@Path("/{param}")
public Response getMsg(@PathParam("param") String msg) {
String output = "Jersey say : " + msg;
return Response.status(200).entity(output).build();
}
}
Tomcat が Java 構成ファイルから構成を直接ロードする可能性はありますか? それは私がapp-config.xmlに持っているもの<context:component-scan base-package="domain,api,config" />
です。他に問題がある可能性があり、AuthResourceクラスでuserDaoのnullpointer例外が発生するのはなぜですか?