Estado HTTP 500 - Ошибка обработки запроса; вложенным исключением является org.hibernate.HibernateException: сеанс не найден для текущего потока

1

Я использую Spring с новичком в спящем режиме, я следовал пошаговым учебным пособиям, но я получаю эту ошибку сеанса, но не знаю, как ее исправить, может ли кто-нибудь мне помочь? Большое спасибо. Контунтуация, которую я пишу, дает мне ошибку в коде, который я написал.

Grave: El Servlet.service() para el servlet [springapp] en el contexto con ruta [/springapp] lanzó la excepción [Обработка запроса не удалась; Вложенное исключение - org.hibernate.HibernateException: сеанс не найден для текущего потока] con causa raíz org.hibernate.HibernateException: сеанс не найден для текущего потока в org.springframework.orm.hibernate4.SpringSessionContext.currentSession(SpringSessionContext.java:97) на org.hibernate.internal.SessionFactoryImpl.getCurrentSession(SessionFactoryImpl.java:978) на com.altobri.conta.dao.EmpresasDAOImpl.listEmpresas(EmpresasDAOImpl.java:43) на com.altobri.conta.service.EmpresasServiceImpl.listEmpresas(EmpresasServiceImpl.java: 47) at com.altobri.conta.controller.empresaListaController.list(empresaListaController.java:30) at sun.reflect.NativeMethodAccessorImpl.invoke0 (собственный метод) на sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57 ) на sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) в java.lang.reflect.Method.invoke(Method.java:606) в org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHa ndlerMethod (HandlerMethodInvoker.java:176). java: 428) в org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:925) в org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:856) в org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:936) в org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:827) в javax.servlet.http.HttpServlet.service(HttpServlet.java:621) в org. springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:812) в javax.servlet.http.HttpServlet.service(HttpServlet.java:728) в org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java: 305) на org.a pache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) в org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51) в org.apache.catalina.core.ApplicationFilterChain.internalDoFilter( ApplicationFilterChain.java:243) на org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) на org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222) на org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123) в org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502) в org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171 ) на org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) на org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953) на org.apache.catalina.core.StandardEngineValve. invoke (StandardEngineValve.java:118) в org.apache.catalina.connector.CoyoteAdapter.service(Coyo teAdapter.java:408) на org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1041) на org.apache.coyote.AbstractProtocol $ AbstractConnectionHandler.process(AbstractProtocol.java:603) на org.apache.tomcat.util.net.JIoEndpoint $ SocketProcessor.run(JIoEndpoint.java:312) в java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) в java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java: 615) в java.lang.Thread.run(Thread.java:744)

web.xml

 <?xml version="1.0" encoding="UTF-8"?>
 <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xmlns="http://java.sun.com/xml/ns/javaee"
 xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
 id="WebApp_ID" version="2.5">
 <display-name>Spring3MVC</display-name>
 <welcome-file-list>
     <welcome-file>index.jsp</welcome-file>
 </welcome-file-list>

 <servlet>

springapp-servlet.xml

<beans xmlns="http://www.springframework.org/schema/beans"
   xmlns:context="http://www.springframework.org/schema/context"
   xmlns:p="http://www.springframework.org/schema/p"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   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">

   <context:component-scan base-package="com.companyname.springapp.web" />
   <context:component-scan base-package="com.springHibernate" />
   <context:component-scan base-package="com.altobri.conta.*" />

 <bean id="viewResolver"
        class="org.springframework.web.servlet.view.UrlBasedViewResolver">
        <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="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="com.mysql.jdbc.Driver" />
    <property name="url" value="jdbc:mysql://localhost:3306/empresas" />
    <property name="username" value="root" />
    <property name="password" value="" />
  </bean>

  <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
    <property name="dataSource" ref="dataSource"></property>
     <property name="annotatedClasses">
            <list>
                <value>com.altobri.conta.model.Empresas</value>
            </list>
        </property>
    <property name="hibernateProperties">
      <props>
        <prop 
         key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>
        <prop key="hibernate.show_sql">true</prop>
      </props>
    </property>
  </bean>

    <bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager" 
    p:sessionFactory-ref="sessionFactory">
  </bean>
</beans>



 <servlet-name>springapp</servlet-name>
    <servlet-class>
        org.springframework.web.servlet.DispatcherServlet
    </servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>springapp</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>

empresaListaController.java

package com.altobri.conta.controller;

import java.util.List;
import java.util.Map;

import org.apache.log4j.Logger;
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;
import org.springframework.ui.Model;
import org.springframework.ui.ModelMap;
import org.springframework.web.servlet.ModelAndView;

import com.altobri.conta.model.Empresas;
import com.altobri.conta.service.*;

@Controller
public class empresaListaController {

    @Autowired
    private EmpresasService empresasService;
    protected final Logger logger = Logger.getLogger(getClass());


    @RequestMapping("/empresaLista")
    // @RequestMapping(method = RequestMethod.GET)
    public String list(Model model) {

      List<Empresas> empresas = empresasService.listEmpresas();
      model.addAttribute("empresalist", empresas);
      return "empresaLista";
    }
}

EmpresasDAO

package com.altobri.conta.dao;

import com.altobri.conta.model.Empresas;
import java.util.List;

public interface EmpresasDAO {
    void persistEmpresas(Empresas empresas);

    Empresas findEmpresasById(int clave);

    void updateEmpresas(Empresas empresas);

    void deleteEmpresas(Empresas empresas);

    public List<Empresas> listEmpresas();

}

EmpresasDAOImpl.java

package com.altobri.conta.dao;

import java.util.List;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;

import com.altobri.conta.model.Empresas;

@Repository("empresasDAO")
public class EmpresasDAOImpl implements EmpresasDAO {

    @Autowired
    public SessionFactory sessionFactory;

    @Override
    public void persistEmpresas(Empresas empresas) {
        sessionFactory.getCurrentSession().persist(empresas);
    }

    @Override
    public Empresas findEmpresasById(int clave) {
        return (Empresas) sessionFactory.getCurrentSession().get(
                Empresas.class, clave);
    }

    @Override
    public void updateEmpresas(Empresas empresas) {
        sessionFactory.getCurrentSession().update(empresas);

    }

    @Override
    public void deleteEmpresas(Empresas empresas) {
        sessionFactory.getCurrentSession().delete(empresas);

    }

    @Override
    public List<Empresas> listEmpresas() {
        Session session = sessionFactory.getCurrentSession();
        List empresas = session.createQuery("from Empresas").list();
        // TODO Auto-generated method stub
         return empresas;
    }

}

Empresas.java

package com.altobri.conta.model;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;

@Entity
@Table(name = "EMPRESAS")
public class Empresas {

    @Id
    @Column(name = "CLAVE", nullable = false)
    private int clave;

    @Column(name = "NOMBRE", nullable = false)
    private String nombre;


    public Empresas() {


    }


    public int getClave() {
        return clave;
    }


    public void setClave(int clave) {
        this.clave = clave;
    }


    public String getNombre() {
        return nombre;
    }


    public void setNombre(String nombre) {
        this.nombre = nombre;
    }



}

EmpresasService.java

package com.altobri.conta.service;



import java.util.List;

import com.altobri.conta.model.Empresas;

public interface EmpresasService {

    void persistEmpresas(Empresas empresas);

    Empresas findEmpresasById(int clave);

    void updateEmpresas(Empresas empresas);

    void deleteEmpresas(Empresas empresas);

    public List<Empresas> listEmpresas();
}

EmpresasServiceImpl.java

package com.altobri.conta.service;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import com.altobri.conta.dao.EmpresasDAO;
import com.altobri.conta.model.Empresas;

@Service("empresasService")
public class EmpresasServiceImpl implements EmpresasService{

    @Autowired
    EmpresasDAO empresasDAO;

    @Override
    @Transactional
    public void persistEmpresas(Empresas empresas) {
        empresasDAO.persistEmpresas(empresas);

    }

    @Override
    @Transactional
    public void updateEmpresas(Empresas empresas) {
        empresasDAO.updateEmpresas(empresas);

    }
    @Override
    @Transactional
    public Empresas findEmpresasById(int clave) {
        return empresasDAO.findEmpresasById(clave);
    }

    @Override
    @Transactional
    public void deleteEmpresas(Empresas empresas) {
        empresasDAO.deleteEmpresas(empresas);

    }

    @Override
    public List<Empresas> listEmpresas() {
        // TODO Auto-generated method stub
        return empresasDAO.listEmpresas();
    }

}
  • 0
    Исправьте ваши web.xml и фрагменты конфигурации Spring. Они размещены переплетены.
  • 0
    Извините, не могли бы вы сказать мне, где ошибка, я скопировал, как я его установил, спасибо
Показать ещё 1 комментарий
Теги:
spring
hibernate
session

2 ответа

1
Лучший ответ

Вам необходимо обновить значение, которое у вас есть в springapp-servlet.xml разделе

<property name="hibernateProperties">

Используйте следующее значение для контекста сеанса.

<prop key="hibernate.current_session_context_class">thread</prop>

thread is short для org.hibernate.context.internal.ThreadLocalSessionContext

Пожалуйста, проверьте эту ссылку для получения более подробной информации.

http://docs.jboss.org/hibernate/orm/4.1/manual/en-US/html_single/#architecture-current-session

  • 0
    Я добавил то, что вы сказали мне, но теперь я прыгаю эту ошибку, но не знаю, как ее исправить.
  • 0
    Та же ошибка: не найден сеанс для текущего потока?
Показать ещё 2 комментария
0

У меня также есть другой способ заставить его работать.

  1. Включите <tx:annotation-driven/> весной xml.

  2. Добавьте аннотацию Transactional в метод Service (getCurrentSession() в рамках транзакции.):

    @Transactional
    public List<Empresas> listEmpresas(){
    return empresasDAO.listEmpresas();}
    
  3. Удалить <prop key="hibernate.current_session_context_class">thread</prop>

Я думаю, что этот способ лучше, так openSession метод openSession не должен использоваться, когда сеанс уже существует.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню