| public void valuebound(httpsessionbindingevent event) public void valueunbound(httpsessionbindingevent event) | 
| public class httpsessionbinding implements javax.servlet.http.httpsessionbindinglistener { servletcontext application = null; public httpsessionbinding(servletcontext application) { super(); if (application ==null) throw new illegalargumentexception("null application is not accept."); this.application = application; } public void valuebound(javax.servlet.http.httpsessionbindingevent e) { vector activesessions = (vector) application.getattribute("activesessions"); if (activesessions == null) { activesessions = new vector(); } jdbcuser sessionuser = (jdbcuser)e.getsession().getattribute("user"); if (sessionuser != null) { activesessions.add(e.getsession()); } application.setattribute("activesessions",activesessions); } public void valueunbound(javax.servlet.http.httpsessionbindingevent e) { jdbcuser sessionuser = (jdbcuser)e.getsession().getattribute("user"); if (sessionuser == null) { vector activesessions = (vector) application.getattribute("activesessions"); if (activesessions != null) { activesessions.remove(e.getsession().getid()); application.setattribute("activesessions",activesessions); } } } } | 
| public void login() throws aclexception,sqlexception,ioexception { /* get jdbc user class */ if (user != null) { logout(); } { // if session time out, or user didn't login, save the target url temporary. jdbcuserfactory uf = new jdbcuserfactory(); if ( (this.request.getparameter("userid")==null) || (this.request.getparameter("password")==null) ) { throw new aclexception("please input a valid username and password."); } jdbcuser user = (jdbcuser) uf.userlogin( this.request.getparameter("userid"), this.request.getparameter("password") ); user.touchlogintime(); this.session.setattribute("user",user); this.session.setattribute("bindingnotify",new httpsessionbinding(application)); } } | 
| public void logout() throws sqlexception,aclexception { if (this.user == null && this.session.getattribute("user")==null) { return; } vector activesessions = (vector) this.application.getattribute("activesessions"); if (activesessions != null) { activesessions.remove(this.session); application.setattribute("activesessions",activesessions); } java.util.enumeration e = this.session.getattributenames(); while (e.hasmoreelements()) { string s = (string)e.nextelement(); this.session.removeattribute(s); } this.user.touchlogouttime(); this.user = null; } | 
   這兩個函數位于一個httpsessionmanager類中.這個類引用了jsp里面的application全局對象。這個類的其他代碼和本文無關且相當長,我就不貼出來了。
下面來看看jsp里面怎么用。
  假設一個登錄用的表單被提交到dologin.jsp, 表單中包含username和password域。節選部分片段:
 
| <% httpsessionmanager hsm = new httpsessionmanager(application,request,response); try { hsm.login(); } catch ( usernotfoundexception e) { response.sendredirect("insufficientprivilege.jsp?detail=user%20does%20not%20exist."); return; } catch ( invalidpasswordexception e2) { response.sendredirect("insufficientprivilege.jsp?detail=invalid%20password"); return; } catch ( exception e3) { %> error:<%=e3.tostring() %><br> press <a href="login.jsp">here</a> to relogin. <% return; } response.sendredirect("index.jsp"); %> | 
| <body bgcolor="#ffffff"> <table cellspacing="0" cellpadding="0" width="100%"> <tr > <td >sessionid </td> <td >user </td> <td >login time </td> <td >last access time </td> </tr> <% vector activesessions = (vector) application.getattribute("activesessions"); if (activesessions == null) { activesessions = new vector(); application.setattribute("activesessions",activesessions); } iterator it = activesessions.iterator(); while (it.hasnext()) { httpsession sess = (httpsession)it.next(); jdbcuser sessionuser = (jdbcuser)sess.getattribute("user"); string userid = (sessionuser!=null)?sessionuser.getuserid():"none"; %> <tr> <td nowrap=''><%= sess.getid() %></td> <td nowrap=''><%= userid %></td> <td nowrap=''> <%= beacondate.getinstance( new java.util.date(sess.getcreationtime())).getdatetimestring()%></td> <td class="<%= stl %>3" nowrap=''> <%= beacondate.getinstance( new java.util.date(sess.getlastaccessedtime())).getdatetimestring()%></td> </tr> <% } %> </table> </body> | 
新聞熱點
疑難解答