隨筆 - 6  文章 - 129  trackbacks - 0
          <2025年6月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345

          常用鏈接

          留言簿(14)

          隨筆檔案(6)

          文章分類(467)

          文章檔案(423)

          相冊

          收藏夾(18)

          JAVA

          搜索

          •  

          積分與排名

          • 積分 - 827660
          • 排名 - 49

          最新評論

          閱讀排行榜

          評論排行榜

          實現的功能:   通過Hibernate的工具類得到一個全局唯一的SessionFactory對象
                                  通過SessionFactory對象得到Session對象,然后開始一個新的事務
                                  通過chain對象的doFilter()方法來完成業務處理
                                  提交或者回滾事務.

          HibernateFilter.java

          import java.io.IOException;

          import javax.servlet.Filter;
          import javax.servlet.FilterChain;
          import javax.servlet.FilterConfig;
          import javax.servlet.ServletException;
          import javax.servlet.ServletRequest;
          import javax.servlet.ServletResponse;
          import javax.servlet.http.HttpServletRequest;

          import org.apache.commons.logging.Log;
          import org.apache.commons.logging.LogFactory;
          import org.hibernate.SessionFactory;

          import cn.hxex.blog.hibernate.HibernateUtil;

          public class HibernateFilter implements Filter {

              private static Log log = LogFactory.getLog(HibernateFilter.class);

              /**
               * 過濾器的主要方法
               * 用于實現Hibernate事務的開始和提交
               */
              public void doFilter(ServletRequest request,
                                   ServletResponse response,
                                   FilterChain chain)
                      throws IOException, ServletException
              {
               // 得到SessionFactory對象的實例
               SessionFactory sf = HibernateUtil.getSessionFactory();

                  try
                  {
                   // 開始一個新的事務
                      log.debug("Starting a database transaction");
                      sf.getCurrentSession().beginTransaction();

                      log.debug( "Request Path:\t" + ((HttpServletRequest)request).getServletPath() );
                      // Call the next filter (continue request processing)
                      chain.doFilter(request, response);

                      // 提交事務
                      log.debug("Committing the database transaction");
                      sf.getCurrentSession().getTransaction().commit();

                  }
                  catch (Throwable ex)
                  {
                   ex.printStackTrace();
                      try
                      {
                       // 回滾事務
                          log.debug("Trying to rollback database transaction after exception");
                          sf.getCurrentSession().getTransaction().rollback();
                      }
                      catch (Throwable rbEx)
                      {
                          log.error("Could not rollback transaction after exception!", rbEx);
                      }

                      // 拋出異常
                      throw new ServletException(ex);
                  }
              }

              /**
               * Servlet過濾器的初始化方法
               * 可以讀取配置文件中設置的配置參數
               */
              public void init(FilterConfig filterConfig) throws ServletException {}

              /**
               * Servlet的銷毀方法
               * 用于釋放過濾器所申請的資源
               */
              public void destroy() {}

          }



          posted on 2007-08-29 21:29 Ke 閱讀(750) 評論(0)  編輯  收藏 所屬分類: hibernate
          主站蜘蛛池模板: 郁南县| 大石桥市| 裕民县| 台州市| 巩留县| 通道| 浦东新区| 江陵县| 彭阳县| 镇赉县| 北流市| 依兰县| 西华县| 南郑县| 革吉县| 凉山| 宁南县| 墨脱县| 双牌县| 汝南县| 全椒县| 芮城县| 东乡族自治县| 澄迈县| 克山县| 桑日县| 汉川市| 图片| 泸州市| 太仆寺旗| 林芝县| 故城县| 富源县| 柳林县| 随州市| 凤翔县| 扎鲁特旗| 三明市| 佛冈县| 花垣县| 双桥区|