How do I get spring to inject my EntityManager?
I'm following the guide here, but when the DAO executes, the EntityManager
is null
.
I've tried a number of fixes I found in the comments on the guide, on various forums, and here (including this), to no avail. No matter what I seem to do the EntityManager
remains null
.
Here are the relevant files, with packages etc changed to protect the innocent.
spring-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: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.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"
xmlns:p="http://www.springframework.org/schema/p">
<context:component-scan base-package="com.group.server"/>
<context:annotation-config/>
<tx:annotation-driven/>
<bean id="propertyPlaceholderConfigurer"
class="com.group.DecryptingPropertyPlaceholderConfigurer"
p:systemPropertiesModeName="SYSTEM_PROPERTIES_MODE_OVERRIDE">
<property name="locations">
<list>
<value>classpath*:spring-*.properties</value>
<value>classpath*:${application.environment}.properties</value>
</list>
</property>
</bean>
<bean id="orderDao" class="com.package.service.OrderDaoImpl"/>
开发者_如何学Go<bean class="org.springframework.orm.jpa.support.PersistenceAnnotationBeanPostProcessor"/>
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="persistenceUnitName" value="MyServer"/>
<property name="loadTimeWeaver">
<bean class="org.springframework.instrument.classloading.InstrumentationLoadTimeWeaver"/>
</property>
<property name="dataSource" ref="dataSource"/>
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
<property name="showSql" value="${com.group.server.vendoradapter.showsql}"/>
<property name="generateDdl" value="${com.group.server.vendoradapter.generateDdl}"/>
<property name="database" value="${com.group.server.vendoradapter.database}"/>
</bean>
</property>
</bean>
<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory"/>
<property name="dataSource" ref="dataSource"/>
</bean>
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="${com.group.server.datasource.driverClassName}"/>
<property name="url" value="${com.group.server.datasource.url}"/>
<property name="username" value="${com.group.server.datasource.username}"/>
<property name="password" value="${com.group.server.datasource.password}"/>
</bean>
<bean id="executorService" class="java.util.concurrent.Executors" factory-method="newCachedThreadPool"/>
</beans>
persistence.xml
<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="1.0">
<persistence-unit name="MyServer" transaction-type="RESOURCE_LOCAL"/>
</persistence>
OrderDaoImpl
package com.group.service;
import com.group.model.Order;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.Query;
import java.util.List;
@Repository
@Transactional
public class OrderDaoImpl implements OrderDao {
private EntityManager entityManager;
@PersistenceContext
public void setEntityManager(EntityManager entityManager) {
this.entityManager = entityManager;
}
@Override
public Order find(Integer id) {
Order order = entityManager.find(Order.class, id);
return order;
}
@Override
public List<Order> findAll() {
Query query = entityManager.createQuery("select o from Order o");
return query.getResultList();
}
@Override
public List<Order> findBySymbol(String symbol) {
Query query = entityManager.createQuery("select o from Order o where o.symbol = :symbol");
return query.setParameter("symbol", symbol).getResultList();
}
}
Have you tried adding unitName="MyServer"
to your @PersistenceContext annotation?
Use the org.springframework.orm.jpa.support.PersistenceAnnotationBeanPostProcessor
.
just a thought...are you having this entry in the web.xml
<servlet>
<servlet-name>dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:/META-INF/spring-context.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
this will make sure your spring context is loaded and all the objects are injected by spring container...just try if you have missed this...
精彩评论