📄 dlog_hibernatefilter.java
字号:
package com.holpe.database;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import org.hibernate.HibernateException;
import com.holpe.common.Globals;
/**
* A servlet filter that opens and closes a Hibernate Session for each request.
* <p>
* This filter guarantees a sane state, committing any pending database
* transaction once all other filters (and servlets) have executed. It also
* guarantees that the Hibernate <tt>Session</tt> of the current thread will
* be closed before the response is send to the client.
* <p>
* Use this filter for the <b>session-per-request</b> pattern and if you are
* using <i>Detached Objects</i>.
*
* @see HibernateUtils
* @author Christian Bauer <christian@hibernate.org>
*/
public class DLOG_HibernateFilter implements Filter {
private ServletContext context = null;
private boolean commit_on_close = false;
public void init(FilterConfig filterConfig) throws ServletException {
context = filterConfig.getServletContext();
if(Globals.WEBAPP_PATH==null)
Globals.WEBAPP_PATH = context.getRealPath("");
commit_on_close = "true".equalsIgnoreCase(filterConfig
.getInitParameter("commit_on_close"));
}
/**
* 请求完毕后释放数据库资源
*/
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
try {
// We don't start the database transaction here, but when first needed
chain.doFilter(request, response);
//User must commit the transaction manual
if(commit_on_close){
HibernateUtil.commit();
}
} catch(HibernateException e) {
if(commit_on_close){
HibernateUtil.rollback();
}
} finally {
// No matter what happens, close the Session.
try {
HibernateUtil.closeSession();
} catch (HibernateException ex) {
if(context!=null)
context.log("Exception when close hibernate session", ex);
}
}
}
public void destroy() {
// 释放Hibernate
HibernateUtil.destroy();
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -