快速业务通道

让不同的Servlet在一个Session共享连接 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-18
ion"); 7 8     // 如果不在,就创建一个数据库连接,并把它交给持有者。 9     if (holder == null) { 10      try { 11       holder = new ConnectionHolder(DriverManager.getConnection( "Connection URL")); 12       session.setAttribute("servletapp.connection", holder); 13      } 14      catch (SQLException sqle) { 15       // 错误处理代码 16      } 17     } 18 19     // 从容器取得实际连接 20     conn = holder.getConnection(); 21   }    .... // 别忘了commit   }

这段代码看起来有那么几行。但实际上,在每个session中,只有第一次执行的servlet需要进行数据库连接操作,此后的servlet只会执行第4、6、20这三行。

==== 谁来负责断开连接? ====

当 servlet 们不必再为创建数据库连接费心的时候,也就没有人愿意管关闭连接这档子事了。事实上,更重要的是,他们没法管。因为这个连接是放在 session 中的,而没有谁能准确的预测,一个 session 会何时终止。

好在有一种叫做“******”(Listener)的东西可以专门管这件事。Listener有很多方法,其中的两个方法是:

public void valueBound(HttpSessionBingEvent event);

public void valueUnbound(HttpSessionBingEvent event);

这两个方法可以在一个 session 被创建/失效的时候分别自动执行。我们就把关闭连接的代码放在第二个方法中,这样,当一个 session 失效的时候,数据库连接就会自动关闭。

要想让一个类成为Listener,只需让它实现 HttpSessionBindingListener 接口。我们的 connection 是由 ConnectionHolder 这个类来保管的,因此最方便的办法就是把它注册成一个监听器。

具体方法是:

public void valueUnbound(HttpSessionBindingEvent event) {    // 当从Session删除或当Session结束时,关闭数据连接。    try {      if (con != null) {       con.rollback(); // 放弃所有未提交的数据       con.close();      }    }    catch (SQLException e) {      // 错误处理代码    }   }

让不同的Servlet在一个Session共享连接(3)

时间:2011-03-07

==== 完整示例 ====

下面是一个完整的 ConnectionHolder:

import javax.servlet.http.HttpSessionBindingListener; import javax.servlet.http.HttpSessionBindingEvent; import java.sql.Connection; import java.sql.SQLException; public class ConnectionHolder implements HttpSessionBindingListener {   public ConnectionHolder(Connection con) {    // 保存连接    this.con = con;    try {      con.setAutoCommit(false);    }    catch(SQLException e) {      // 错误处理代码    }   }   public Connection getConnection() {    return con;   }   public void valueBound(HttpSessionBindingEvent event) {    // 当增加Session时,什么也不做   }   public void valueUnbound(HttpSessionBindingEvent event) {    // 当从Session删除或当Session结束时,关闭数据连接。    try {      if (con != null) {       con.rollback(); // 放弃所有未发送数据       con.close();      }    }    catch (SQLException e) {      // 错误处理代码    }   }   private Connection con = null; }

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号