2015-01-06 4 views
1

Я знаю, что это уже задано, но я пробовал все решения, которые я нашел, и они не работали. вот StackTrace:Синхронизированная транзакция Сессия для текущей темы Hibernate4 Исключительная пружина 4

15:47:22,750 ERROR [io.undertow.request] (default task-21) UT005023: Exception handling request to /usuarios/user/: org.springframework.web.util.NestedServletException: Request processing failed; nested exception is org.hibernate.HibernateException: Could not obtain transaction-synchronized Session for current thread 
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:978) [spring-webmvc-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:857) [spring-webmvc-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:687) [jboss-servlet-api_3.1_spec-1.0.0.Final.jar:1.0.0.Final] 
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:842) [spring-webmvc-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:790) [jboss-servlet-api_3.1_spec-1.0.0.Final.jar:1.0.0.Final] 
at io.undertow.servlet.handlers.ServletHandler.handleRequest(ServletHandler.java:85) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.servlet.handlers.security.ServletSecurityRoleHandler.handleRequest(ServletSecurityRoleHandler.java:61) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.servlet.handlers.ServletDispatchingHandler.handleRequest(ServletDispatchingHandler.java:36) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
at org.wildfly.extension.undertow.security.SecurityContextAssociationHandler.handleRequest(SecurityContextAssociationHandler.java:78) 
at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.servlet.handlers.security.SSLInformationAssociationHandler.handleRequest(SSLInformationAssociationHandler.java:131) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.servlet.handlers.security.ServletAuthenticationCallHandler.handleRequest(ServletAuthenticationCallHandler.java:56) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.security.handlers.AbstractConfidentialityHandler.handleRequest(AbstractConfidentialityHandler.java:45) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.servlet.handlers.security.ServletConfidentialityConstraintHandler.handleRequest(ServletConfidentialityConstraintHandler.java:63) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.security.handlers.AuthenticationMechanismsHandler.handleRequest(AuthenticationMechanismsHandler.java:58) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.servlet.handlers.security.CachedAuthenticatedSessionHandler.handleRequest(CachedAuthenticatedSessionHandler.java:70) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.security.handlers.SecurityInitialHandler.handleRequest(SecurityInitialHandler.java:76) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
at org.wildfly.extension.undertow.security.jacc.JACCContextIdHandler.handleRequest(JACCContextIdHandler.java:61) 
at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.servlet.handlers.ServletInitialHandler.handleFirstRequest(ServletInitialHandler.java:261) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.servlet.handlers.ServletInitialHandler.dispatchRequest(ServletInitialHandler.java:247) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.servlet.handlers.ServletInitialHandler.access$000(ServletInitialHandler.java:76) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.servlet.handlers.ServletInitialHandler$1.handleRequest(ServletInitialHandler.java:166) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.server.Connectors.executeRootHandler(Connectors.java:197) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
at io.undertow.server.HttpServerExchange$1.run(HttpServerExchange.java:759) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) [rt.jar:1.8.0_25] 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) [rt.jar:1.8.0_25] 
at java.lang.Thread.run(Thread.java:745) [rt.jar:1.8.0_25] 
Caused by: org.hibernate.HibernateException: Could not obtain transaction-synchronized Session for current thread 
at org.springframework.orm.hibernate4.SpringSessionContext.currentSession(SpringSessionContext.java:134) [spring-orm-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
at org.hibernate.internal.SessionFactoryImpl.getCurrentSession(SessionFactoryImpl.java:1014) [hibernate-core-4.3.7.Final.jar:4.3.7.Final] 
at com.esprbca.usuarios.dao.impl.UsuarioDaoImpl.listUsuarios(UsuarioDaoImpl.java:56) [classes:] 
at com.esprbca.usuarios.service.impl.UsuarioServiceImpl.listUsuarios(UsuarioServiceImpl.java:42) [classes:] 
at com.esprbca.usuarios.controller.UsuariosController.paginaUsuarios(UsuariosController.java:64) [classes:] 
at com.esprbca.usuarios.controller.UsuariosController.GET(UsuariosController.java:35) [classes:] 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) [rt.jar:1.8.0_25] 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) [rt.jar:1.8.0_25] 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) [rt.jar:1.8.0_25] 
at java.lang.reflect.Method.invoke(Method.java:483) [rt.jar:1.8.0_25] 
at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:221) [spring-web-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:137) [spring-web-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:110) [spring-webmvc-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:777) [spring-webmvc-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:706) [spring-webmvc-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85) [spring-webmvc-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:943) [spring-webmvc-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:877) [spring-webmvc-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:966) [spring-webmvc-4.1.3.RELEASE.jar:4.1.3.RELEASE] 
... 30 more 

это моя web.xml:

<?xml version="1.0" encoding="UTF-8"?> 
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> 

<!-- The definition of the Root Spring Container shared by all Servlets and Filters --> 
<context-param> 
    <param-name>contextConfigLocation</param-name> 
    <param-value>classpath:spring-hibernate.xml</param-value> 
</context-param> 

<!-- Creates the Spring Container shared by all Servlets and Filters --> 
<listener> 
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 
</listener> 

<!-- Processes application requests --> 
<servlet> 
    <servlet-name>appServlet</servlet-name> 
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 
    <init-param> 
     <param-name>contextConfigLocation</param-name> 
     <param-value>classpath:servlet-context.xml</param-value> 
    </init-param> 
    <load-on-startup>1</load-on-startup> 
</servlet> 

<servlet-mapping> 
    <servlet-name>appServlet</servlet-name> 
    <url-pattern>/</url-pattern> 
</servlet-mapping> 

</web-app> 

сервлет-context.xml:

<?xml version="1.0" encoding="UTF-8"?> 
<beans:beans xmlns="http://www.springframework.org/schema/mvc" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xmlns:beans="http://www.springframework.org/schema/beans" 
xmlns:aop="http://www.springframework.org/schema/aop" 
xmlns:context="http://www.springframework.org/schema/context" 
xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd 
    http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd 
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> 

<!-- DispatcherServlet Context: defines this servlet's request-processing infrastructure --> 

<!-- Enables the Spring MVC @Controller programming model --> 
<annotation-driven /> 

<!-- Handles HTTP GET requests for /resources/** by efficiently serving up static resources in the ${webappRoot}/resources directory --> 
<resources mapping="/static/**" location="/static/" /> 

<!-- Resolves views selected for rendering by @Controllers to .jsp resources in the /WEB-INF/views directory --> 
<beans:bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> 
    <beans:property name="prefix" value="/WEB-INF/views/" /> 
    <beans:property name="suffix" value=".jsp" /> 
</beans:bean> 

<context:component-scan base-package="com.esprbca.usuarios.controller,com.esprbca.usuarios.service,com.esprbca.usuarios.dao" /> 

</beans:beans> 

весна-hibernate.xml:

<?xml version="1.0" encoding="UTF-8"?> 
<beans> 
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> 
    <property name="locations"> 
     <list> 
      <value>classpath:config.properties</value> 
     </list> 
    </property> 
</bean> 

<bean id="escaDataSource" class="org.springframework.jndi.JndiObjectFactoryBean"> 
    <property name="jndiName" value="${jdniName}" /> 
</bean> 

<!-- hibernate session --> 
<bean id="sessionFactory" 
    class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> 
    <property name="dataSource" ref="escaDataSource" /> 
    <property name="hibernateProperties"> 
     <props> 
      <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop> 
      <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.use_sql_comments">${hibernate.use_sql_comments}</prop> 
     </props> 
    </property> 

    <!-- autoscan annotation for hiberante config --> 
    <property name="packagesToScan"> 
     <list> 
      <value>com.esprbca.usuarios.entities</value> 
     </list> 
    </property> 
</bean> 

<!-- transaction manager --> 
<bean name="transactionManager" 
    class="org.springframework.orm.hibernate4.HibernateTransactionManager"> 
    <property name="sessionFactory" ref="sessionFactory"></property> 
</bean> 
<!-- the transactional advice (what happens; see the <aop:advisor/> bean below) --> 
<tx:advice id="txAdvice" transaction-manager="transactionManager"> 
    <!-- the transactional semantics... --> 
    <tx:attributes> 
     <!-- all methods starting with get are read-only --> 
     <tx:method name="retrieve*" read-only="true"/> 
     <!-- other methods use the default transaction settings (see below) --> 
     <tx:method name=""/> 
    </tx:attributes> 
</tx:advice> 

<!-- ensure that the above transactional advice runs for any execution 
    of an operation defined by the serviceUpdateOperations --> 
<aop:config> 
    <aop:pointcut id="serviceUpdateOperations" 
        expression="execution(* com.esprbca.usuarios.service.impl.*.*(..))"/> 
    <aop:advisor advice-ref="txAdvice" pointcut-ref="serviceUpdateOperations"/> 
</aop:config> 
</beans> 

Контроллер:

@Controller 
public class UsuariosController /* implements Controller */ { 

protected final Log logger = LogFactory.getLog(getClass()); 

@Autowired 
private UsuarioServiceI usuarioService; 


@RequestMapping(value="/user") 
public ModelAndView GET(HttpServletRequest request, HttpServletResponse response){ 
    logger.error("passed controller"); 
    return paginaUsuarios(); 
} 
public ModelAndView paginaUsuarios(){ 
    Collection<Usuario> usuariosList = usuarioService.listUsuarios(); 
    Map<String, Object> model = new HashMap<String, Object>(); 
    model.put("usuarios", usuariosList); 
    ModelAndView mv = new ModelAndView("usuarios", "model", model); 
    return mv; 
}} 

Услуги:

@Service 
@Transactional 
public class UsuarioServiceImpl implements UsuarioServiceI{ 

@Autowired 
private UsuarioDaoI usuarioDAO; 

public void setUsuarioDAO(UsuarioDaoI usuarioDAO) { 
    this.usuarioDAO = usuarioDAO; 
} 

@Override 
@Transactional 
public void addUsuario(String usuario, String passwd, String nombres, 
     String apellidos, String email, String telefono, int perfilid, 
     boolean activo) { 
    this.usuarioDAO.addUsuario(usuario, passwd, nombres, 
      apellidos, email, telefono, perfilid, activo); 
} 

@Override 
@Transactional 
public void updateUsuario(Usuario u) { 
    this.updateUsuario(u); 
} 

@Override 
@Transactional 
public List<Usuario> listUsuarios() { 
    return this.usuarioDAO.listUsuarios(); 
} 

@Override 
@Transactional 
public Usuario getUsuarioById(String usuario) { 
    return this.usuarioDAO.getUsuarioById(usuario); 
} 

@Override 
@Transactional 
public List<Usuario> getUsuariosLike(String pattern) { 
    return this.usuarioDAO.getUsuariosLike(pattern); 
}} 

DAO:

@Repository 
@Transactional 
public class UsuarioDaoImpl implements UsuarioDaoI{ 

private static final Logger logger = LoggerFactory.getLogger(UsuarioDaoImpl.class); 

@Autowired 
private SessionFactory sessionFactory; 

public void setSessionFactory(SessionFactory sf){ 
    this.sessionFactory = sf; 
} 

@SuppressWarnings("unchecked") 
@Transactional 
public List<Usuario> listUsuarios() { 
    List<Usuario> usuarioList = (List<Usuario>) sessionFactory. 
       getCurrentSession().createCriteria(Usuario.class).list(); 
    return usuarioList; 
}} 

любая помощь будет оценена

+1

Ваша конфигурация транзакции загружается 'ContextLoaderListener' в то время как ваши услуги будут загружены в' DispatcherServlet', что не собирается работать. AOP работает только в том же контексте, в котором он определен. –

+0

чем вы, вы мне очень помогли, одна из проблем заключается в том, что в контексте сервлета я просматривал все анотированные классы, решение: сканировать только анотированные контроллеры в сервлетах контекст и реализация dao и сервисов в контексте hibernate – lennin92

ответ

2

Ряд пунктов:

  1. Вам нужно только аннотацию транзакционных на ваших методах класса обслуживания или в верхней части класса, чтобы сделать все методы транзакционного , Общий стандарт - аннотировать методы. Аннотирование @Transactional на вашем DAO - это плохая практика, и ее следует избегать.

  2. Попытка установить DAO в вашем классе обслуживания и вашей фабрике сеансов в вашем DAO с помощью сеттера и не полагаться на версию @Autowired, вероятно, является основной причиной вашей проблемы.

  3. Ваша конфигурация AOP не требуется вообще, Hibernate должен просто работать из коробки. Вы можете найти вопрос, который я написал here, чтобы быть полезным. Он дает вам руководство по настройке Hibernate 4 с Spring 3 для управления транзакциями.

удачи

+0

большое спасибо, на самом деле, одна из проблем заключалась в том, что я попытался использовать набор dao для класса сервиса и сеанса в классе dao вместо того, чтобы использовать @autowired. – lennin92

Смежные вопросы