轉自:http://www.javashuo.com/article/p-djvxxiuf-dr.htmlhtml
1 什麼是單點登錄java
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下 web
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),能夠判斷該用戶是否在線.數據庫
轉自:http://blog.csdn.net/java_freshman01/article/details/7202776瀏覽器
採用SSH架構加以說明:
1. 創建一個登陸管理類LoginManager
2. 在LoginManager中定義一個集合,管理登陸的用戶。
3. 在Spring中將LoginManager配置成單例
4. 若是使用自定義的用戶管理類,則爲了說明方便,將此類命名爲UserContext(表示用戶受權的上下文)
5. 若是未使用自定義的用戶管理類,則直接使用Session。
6. 在登陸受權對象中,檢查用戶是不是合法用戶,若是是合法用戶,則在LoginManager的集合中查找用戶是否已經在線,若是不在線,則將用戶加入集合。
7. 處理策略一:若是用戶已經在線,則取新登陸用戶的Session,將它失效,則能阻止新登陸用戶登陸。
8. 處理策略二:若是用戶已經在線,則取出在線用戶的Session,將它失效,再把新登陸用戶加入LoginManager的集合。則先登陸用戶不能執行有權限的操做,只能從新登陸。安全
1. applicationContext.xml服務器
1 <bean id="loginManager" class="LoginManager" scope="singleton" /> 2 <bean id="action" class="LoginAction" scopt="prototype" > 3 <property name="laginManager" ref="loginManager" /> 4 </bean>
2. LoginManager.javacookie
1 Collection<Session> sessions; 2 3 public Session login(Session session) { 4 for (Session s : sessions) { 5 if (s 與 session 是同一用戶) 6 策略一: return session 7 策略二:{ 8 sessions.add(session); // 這兩行在循環中操做集合類會拋出異常 9 sessions.remove(s); // 此處僅爲簡單示範代碼,實際代碼中應該在循環外處理 10 return s; 11 } 12 } 13 sessions.add(session); 14 15 return null; 16 }
3. LoginAction.javasession
1 LoginManager loginManager; 2 3 public String execute() throws Exception { 4 取session 5 檢查用戶名,密碼 6 if (是合法用戶) { 7 session = loginManager.login(session); 8 if (null!=session) session.invalidate(); 9 } 10 }
4. 若是自定義了UserContext,則可將集合改爲Collection<UserContext> users;架構
5. UserContext.java
1 Session session; 2 Session getSession() { 3 return this.session; 4 } 5 6 boolean login(String userName, String password) { 7 訪問數據庫,檢查用戶名密碼 8 return 是否合法; 9 } 10 11 boolean sameUser(UserContext uc) { 12 return uc.userName.equals(this.userName); 13 }
6. 修改LoginManager.java
1 Collection<UserContext> users; 2 3 public UserContext login(UserContext user) { 4 for (UserContext uc : users) { 5 if (uc.sameUser(user)) 6 策略一: return user 7 策略二:{ 8 users.add(user); // 這兩行在循環中操做集合類會拋出異常 9 users.remove(uc); // 此處僅爲簡單示範代碼,實際代碼中應該在循環外處理 10 return uc; 11 } 12 } 13 users.add(user); 14 15 return null; 16 }
7. 修改LoginAction.java
1 public String execute() throws Exception { 2 取session // 也能夠在UserContext內部取session。 3 UserContext user = new UserContext(); 4 user.setSession(session); 5 if (user.login(userName, password)) { 6 UserContext uc = loginManager.login(user); 7 if (null!=uc) uc.getSession().invalidate(); 8 } 9 }