简单单点登录实例

[java]  view plain copy
  1. package com.ll.singlelogin;  
  2.   
  3.   
  4. import javax.servlet.http.*;  
  5. import java.util.*;  
  6.   
  7.   
  8. public class SingleLogin implements HttpSessionListener {  
  9.   
  10.   
  11.     // 保存sessionID和username的映射  
  12.     private static HashMap hUserName = new HashMap();  
  13.   
  14.   
  15.     /** 以下是实现HttpSessionListener中的方法* */  
  16.     public void sessionCreated(HttpSessionEvent se) {  
  17.     }  
  18.   
  19.   
  20.     public void sessionDestroyed(HttpSessionEvent se) {  
  21.         hUserName.remove(se.getSession().getId());  
  22.     }  
  23.   
  24.   
  25.     /** 
  26.      * isAlreadyEnter-用于判断用户是否已经登录以及相应的处理方法 
  27.      *  
  28.      * @param sUserName 
  29.      *            String-登录的用户名称 
  30.      * @return boolean-该用户是否已经登录过的标志 
  31.      */  
  32.     public static boolean isAlreadyEnter(HttpSession session, String sUserName) {  
  33.         boolean flag = false;  
  34.         // 如果该用户已经登录过,则使上次登录的用户掉线(依据使用户名是否在hUserName中)  
  35.         if (hUserName.containsValue(sUserName)) {  
  36.             flag = true;  
  37.             // 遍历原来的hUserName,删除原用户名对应的sessionID(即删除原来的sessionID和username)  
  38.             Iterator iter = hUserName.entrySet().iterator();  
  39.             while (iter.hasNext()) {  
  40.                 Map.Entry entry = (Map.Entry) iter.next();  
  41.                 Object key = entry.getKey();  
  42.                 Object val = entry.getValue();  
  43.                 if (((String) val).equals(sUserName)) {  
  44.                     hUserName.remove(key);  
  45.                 }  
  46.             }  
  47.             // 添加现在的sessionID和username  
  48.             hUserName.put(session.getId(), sUserName);  
  49.             System.out.println("hUserName   =   " + hUserName);  
  50.         } else {// 如果该用户没登录过,直接添加现在的sessionID和username  
  51.             flag = false;  
  52.             hUserName.put(session.getId(), sUserName);  
  53.             System.out.println("hUserName   =   " + hUserName);  
  54.         }  
  55.         return flag;  
  56.     }  
  57.   
  58.   
  59.     /** 
  60.      * isOnline-用于判断用户是否在线 
  61.      *  
  62.      * @param session 
  63.      *            HttpSession-登录的用户名称 
  64.      * @return boolean-该用户是否在线的标志 
  65.      */  
  66.     public static boolean isOnline(HttpSession session) {  
  67.         boolean flag = true;  
  68.         if (hUserName.containsKey(session.getId())) {  
  69.             flag = true;  
  70.         } else {  
  71.             flag = false;  
  72.         }  
  73.         return flag;  
  74.     }  
  75. }  

web.xml部署于/App/WEB-INF下 
[html]  view plain copy
  1. <?xml   version"1.0 "   encoding"ISO-8859-1 "?>   
  2.   
  3. <!DOCTYPE   web-app   
  4. PUBLIC   "-//Sun   Microsystems,   Inc.//DTD   Web   Application   2.3//EN "   
  5. "http://java.sun.com/j2ee/dtds/web-app_2.3.dtd ">   
  6.   
  7. <web-app>   
  8.   
  9. <listener>   
  10. <listener-class>   
  11. com.inspirer.dbmp.SessionListener   
  12. </listener-class>   
  13. </listener>   
  14.   
  15. </web-app>   


应用部分 
1.在你的登录验证时,调用SessionListener.isAlreadyEnter(session, "admin ") 
既可以判断该用户名的用户是否登录过,又可以使上次登录的用户掉线 
2.其他页面调用SessionListener.isOnline(session),可以判断该用户是否在线.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值