Spring3.2+Hibernate4.1集成的时候提示找不到Session

问题描述

大家好, 我今天在整合spring3+hibernate的时候老是被提示找不到session  我获取session的方式是sessionFactory.getCurrentSession()控制台报的错误:严重: Servlet.service() for servlet springmvc threw exceptionorg.hibernate.HibernateException: No Session found for current threadat org.springframework.orm.hibernate4.SpringSessionContext.currentSession(SpringSessionContext.java:97)at org.hibernate.internal.SessionFactoryImpl.getCurrentSession(SessionFactoryImpl.java:978)at cn.ccsu.dao.impl.UserDaoImpl.getSession(UserDaoImpl.java:48)at cn.ccsu.dao.impl.UserDaoImpl.exist(UserDaoImpl.java:22)at cn.ccsu.manager.impl.UserManagerImpl.register(UserManagerImpl.java:20)at cn.ccsu.web.UserAction.register(UserAction.java:27)at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)at java.lang.reflect.Method.invoke(Method.java:597)at org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:219)at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:132)at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:104)at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:746)at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:687)at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:80)at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:925)at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:856)at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:915)at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:822)at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:796)at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:859)at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)at java.lang.Thread.run(Thread.java:619) applicationContext.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:aop="http://www.springframework.org/schema/aop" 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.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd"default-autowire="byName"><context:component-scan base-package="cn.ccsu" /><bean id="propertyConfigurer"class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"><property name="locations"><list><value>classpath:config/jdbc.properties</value></list></property></bean><bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"destroy-method="close"><property name="driverClass" value="${hibernate.connection.driver_class}" /><property name="jdbcUrl" value="${hibernate.connection.url}" /><property name="user" value="${hibernate.connection.username}" /><property name="password" value="${hibernate.connection.password}" /></bean><bean id="sessionFactory"class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"><property name="dataSource" ref="dataSource"></property><property name="hibernateProperties"><props><prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop><prop key="hibernate.show_sql">true</prop><prop key="hibernate.format_sql">true</prop><prop key="hibernate.current_session_context_class">org.springframework.orm.hibernate4.SpringSessionContext</prop></props></property><property name="packagesToScan"><value>cn.ccsu.model</value></property></bean><bean id="transactionManager"class="org.springframework.orm.hibernate4.HibernateTransactionManager"><property name="sessionFactory"><ref bean="sessionFactory" /></property></bean><tx:annotation-driven transaction-manager="transactionManager"/></beans> 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>S3SH</display-name><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><context-param><param-name>contextConfigLocation</param-name><param-value>classpath:config/applicationContext.xml</param-value></context-param><filter> <filter-name>OpenSessionInViewFilter</filter-name> <filter-class> org.springframework.orm.hibernate4.support.OpenSessionInViewFilter </filter-class> <!-- 指定在spring配置的sessionFactory --> <init-param> <param-name>sessionFactoryBeanName</param-name> <param-value>mysqlSessionFactory</param-value> </init-param> <!-- singleSession默认为true,若设为false则等于没用OpenSessionInView --> <init-param> <param-name>singleSession</param-name> <param-value>true</param-value> </init-param> </filter> <!-- 处理中文乱码问题 start --><filter><filter-name>UTF-Encoding</filter-name><filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class><init-param><param-name>encoding</param-name><param-value>UTF-8</param-value></init-param><init-param><param-name>forceEncoding</param-name><param-value>true</param-value></init-param></filter><filter-mapping><filter-name>UTF-Encoding</filter-name><url-pattern>/*</url-pattern></filter-mapping><!-- 处理中文乱码问题 end --><!-- springmvc start --><servlet><servlet-name>springmvc</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value>classpath:config/springmvc-servlet.xml</param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>springmvc</servlet-name><url-pattern>*.do</url-pattern></servlet-mapping><!-- springmvc end --></web-app> UserManagerImpl.javapackage cn.ccsu.dao.impl;import java.util.List;import org.hibernate.Query;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Qualifier;import org.springframework.stereotype.Component;import cn.ccsu.dao.UserDao;import cn.ccsu.model.UserBean;@SuppressWarnings("unchecked")@Component("userDao")public class UserDaoImpl implements UserDao {@Overridepublic boolean exist(UserBean userBean) {String hql = "from UserBean userBean where userBean.username=:key";Query q = getSession().createQuery(hql);q.setParameter("key", userBean.getUsername());if (q.list().size() > 0) {return true;}return false;}@Overridepublic UserBean addUser(UserBean userBean) {getSession().save(userBean);return userBean;}@Overridepublic List<UserBean> getAllUserList() {return getSession().createQuery("from UserBean").list();}@Autowired@Qualifier("sessionFactory")private SessionFactory sessionFactory;public Session getSession() {return sessionFactory.getCurrentSession();}} 以上就是这个项目的主要代码了 请各位大神帮我瞧瞧  多谢

解决方案

<prop key="hibernate.current_session_context_class">org.springframework.orm.hibernate4.SpringSessionContext</prop> 注掉试试
解决方案二:
<prop key="hibernate.current_session_context_class">org.springframework.orm.hibernate4.SpringSessionContext</prop>改为:<prop key="hibernate.current_session_context_class">thread</prop>这个试试
解决方案三:
在你测试的类上或方法上加@Transactional
解决方案四:
http://blog.csdn.net/loveyout/article/details/4193894

时间: 2024-12-24 11:44:20

Spring3.2+Hibernate4.1集成的时候提示找不到Session的相关文章

ssh整合-使用spring3.X+Hibernate4.X来做项目,报异常 No Session found for current thread

问题描述 使用spring3.X+Hibernate4.X来做项目,报异常 No Session found for current thread org.hibernate.HibernateException: No Session found for current thread at org.springframework.orm.hibernate4.SpringSessionContext.currentSession(SpringSessionContext.java:97) at

我现在就是想快速集成 把demo里的东西都拉进项目 包括UI所有 现在遇到好多问题 1重复的好多 2.Foundation框架提示找不到了?

问题描述 我现在就是想快速集成  把demo里的东西都拉进项目 包括UI所有 现在遇到好多问题 1重复的好多 2.Foundation框架提示找不到了? 解决方案 报错截图下解决方案二:所需要的框架都加了解决方案三: 解决方案四:/EaseMob/3rdparty/Parse/这个文件夹下的东西都删除了

求指导-JDK运行不了,老提示找不到文件,怎么办?

问题描述 JDK运行不了,老提示找不到文件,怎么办? 我的JDK装好后,在运行是出现这种错误 环境变量是设置好了的 PATH:D:developJavajdk1.7.0_67bin JAVA_HOME:D:developJavajdk1.7.0_67 求指导该怎么办 解决方案 没有百度一下? 参见http://jingyan.baidu.com/article/e5c39bf5819d8939d6603369.html 解决方案二: 确认一下你JDK安装的路径是不是跟这个PATH:D:devel

集成环信UI,现提示找不到方法:asyncRestoreBackupsWithProgress

问题描述 提示找不到实例方法:asyncRestoreBackupsWithProgress,asyncBackupMessagesWithProgress错误位置: "BackupViewController.m"  第106行,158行 解决方案 看起来不像是环信的方法.解决方案二:这个是官方UI里面的方法, 我现在也是怀疑集成了Lite.a的原因,下面想办法集成完整版

连接ACCESS数据库时发生错误提示:找不到可安装的 ISAM

连接ACCESS数据库时发生错误提示:找不到可安装的 ISAM 检查后发现原来是把Data Source写成 DataSource了 错误:<add key="OleConnection" value="Provider=Microsoft.Jet.OleDb.4.0;DataSource=Demo.mdb;" /> 正确:<add key="OleConnection" value="Provider=Microso

加入域时提示找不到网络路径或活动目录缺少dns记录

电脑计算机加入域时提示找不到网络路径|活动目录缺少dns记录.最近总是能看到朋友们在问,客户端加入域时报错: 加入域时出现了以下错误,系统提示找不到网络路径.为什么呢? 常见的原因有这么几种: 1.客户端首要dns,也就是 primary dns没有填写,没有指向DC域控制器的DNS. 2.DC域控制器上没有安装DNS服务. 3.DNS服务器上没有DC域控制器的SRV记录,或者是错误的. 那么如何解决加入域时找不到网络路径的问题呢? 1.修改TCP/IP的设置,将首要primary dns修改为

CB编译好的Exe程序运行会提示找不到xx库之类的解决方法

CB的完全编译问题,大概是初学BCB的朋友们问的最多的问题. 症状就是编译好的Exe程序拷到没有安装BCB的机器上运行会提示找不到xx库之类的,解决方法: 在project->Options->Compiler中点击Release, 在project->Options->Packages中取消Builder with runtime packages的对钩 在project->Options->Linker中取消Use dynamic RTL前的对钩

win8开机提示找不到指定的模组

win8开机提示找不到指定的模组            Win8系统每次开机都会弹出一个提示窗口,上面提示:启动C:windowssystem32configsystemprofileAppDataRoamingcloverFunKoala64.dll时发生问题,找不到指定模块.这个问题怎么解决呢? 首先要解决问题就要先知道FunKoala64.dll 这个是什么文件,经过分析发现这个DLL文件属于风行播放器的一个文件,及有可能是在卸载该软件时没有卸载干净导致. 解决方法: 1.在文件夹地址栏中

安装Win7提示找不到硬盘驱动器怎么办?

Windows 7 安装问题: 找不到硬盘驱动器 在安装 Windows 7 时,可能会出现以下错误消息之一: •未找到任何驱动器. 单击"加载驱动程序"提供用于安装的大容量存储驱动程序. •Windows 安装程序无法将 Windows 配置为在此计算机的硬件上运行. 下面的操作有助于解决此问题. 在安装 Windows 7 的过程中更新存储控制器驱动程序. 您可能需要更新电脑的存储控制器驱动程序. 此驱动程序控制硬盘与电脑其余部分的交互. 方法如下: 1.查看电脑附带的文档或转到制