今天写了一个SpringMVC的小应用,功能很简单,在用户登录的时候如果发现自己没有用户名和密码就点击注册,跳转到注册页面注册一个,如果注册成功,自动跳转到登录页面,否则跳到错误页面。
问题出现在注册成功后登录的时候。如果直接登录不存在这个问题。问题的异常信息如下:
org.hibernate.SessionException: Session is closed!
其他更多的异常信息就不贴出来了,首先想到的是在第一次使用了session的时候,采取了关闭措施,导致第二次使用的时候session是关闭的,所以报出这个错误。于是查看DAO层代码里面是如何使用session的。
1)创建session
private static Session session = HibernateUtil.getSessionFactory().getCurrentSession()
2)使用session
try
{
session.beginTransaction();
String sql = "SELECT USERNAME,PASSWORD FROM CUSTOMER " +
"WHERE USERNAME = '" + customer.Username +"' AND PASSWORD = '"+customer.Password+"';";
Query query = session.createSQLQuery(sql);
result = query.list().size();
session.getTransaction().commit();
}catch(Exception ex){
ex.printStackTrace();
}
第二个方法里面使用的方式也是这样,发现并没有关闭session
经过查阅资料发现:
如果使用的是getCurrentSession来创建session的话,在commit后,session就自动被关闭了,
也就是不用再session.close()了。但是如果使用的是openSession方法创建的session的话,
那么必须显示的关闭session,也就是调用session.close()方法。这样commit后,session并没有关闭
所以,解决办法就有了!
private static Session session = HibernateUtil.getSessionFactory().openSession()