Java Web網站應用中的單點登錄


采用SSH架構加以說明:
1.  建立一個登錄管理類LoginManager
2.  在LoginManager中定義一個集合,管理登錄的用戶。
3.  在Spring中將LoginManager配置成單例
4.  如果使用自定義的用戶管理類,則為了說明方便,將此類命名為UserContext(表示用戶授權的上下文)
5.  如果未使用自定義的用戶管理類,則直接使用Session。
6.  在登錄授權對象中,檢查用戶是否是合法用戶,如果是合法用戶,則在LoginManager的集合中查找用戶是否已經在線,如果不在線,則將用戶加入集合。
7.  處理策略一:如果用戶已經在線,則取新登錄用戶的Session,將它失效,則能阻止新登錄用戶登錄。
8.  處理策略二:如果用戶已經在線,則取出在線用戶的Session,將它失效,再把新登錄用戶加入LoginManager的集合。則先登錄用戶不能執行有權限的操作,只能重新登錄。

代碼片段:
1. applicationContext.xml

<bean id="loginManager" class="LoginManager" scope="singleton" />
<bean id="action" class="LoginAction" scopt="prototype" >
    <property name="laginManager" ref="loginManager" />
</bean>

2. LoginManager.java

Collection<Session> sessions;

public Session login(Session session) {
    for (Session s : sessions) {
        if (s 與 session 是同一用戶)
            策略一: return session
            策略二:{
                sessions.add(session); // 這兩行在循環中操作集合類會拋出異常
                sessions.remove(s);    // 此處僅為簡單示范代碼,實際代碼中應該在循環外處理
                return s;
            }
    }
    sessions.add(session);

    return null;
}

3. LoginAction.java

LoginManager loginManager;

public String execute() throws Exception {
    取session
    檢查用戶名,密碼
    if (是合法用戶) {
        session = loginManager.login(session);
        if (null!=session) session.invalidate();
    }
}

4. 如果自定義了UserContext,則可將集合改成Collection<UserContext> users;

5. UserContext.java

Session session;
Session getSession() {
    return this.session;
}

boolean login(String userName, String password) {
    訪問數據庫,檢查用戶名密碼
    return 是否合法;
}

boolean sameUser(UserContext uc) {
    return uc.userName.equals(this.userName);
}

6. 修改LoginManager.java

Collection<UserContext> users;

public UserContext login(UserContext user) {
    for (UserContext uc : users) {
        if (uc.sameUser(user))
            策略一: return user
            策略二:{
            users.add(user);  // 這兩行在循環中操作集合類會拋出異常
            users.remove(uc); // 此處僅為簡單示范代碼,實際代碼中應該在循環外處理
            return uc;
            }
    }
    users.add(user);

    return null;
}

7. 修改LoginAction.java

public String execute() throws Exception {
    取session // 也可以在UserContext內部取session。
    UserContext user = new UserContext();
    user.setSession(session);
    if (user.login(userName, password)) {
        UserContext uc = loginManager.login(user);
        if (null!=uc) uc.getSession().invalidate();
    }
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM