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 (Sessions : sessions) {
            if (s 与 session 是同一用户)
                      策略一: return session
                      策略二:{
                              sessions.add(session); // 这两行在循环中操作集合类会抛出异常
                              sessions.remove(s);      // 此处仅为简单示范代码,实际代码中应该在循环外处理
                              return s;
                      }
      }
      sessions.add(session);

      returnnull;
}

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() {
      returnthis.session;
}

boolean login(String userName, String password) {
      访问数据库,检查用户名密码
      return是否合法;
}

boolean sameUser(UserContext uc) {
      returnuc.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);

      returnnull;
}

7. 修改LoginAction.java
public String execute() throws Exception {
      取session //也可以在UserContext内部取session。
      UserContextuser = new UserContext();
      user.setSession(session);
      if(user.login(userName, password)) {
              UserContext uc = loginManager.login(user);
              if (null!=uc) uc.getSession().invalidate();
      }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值