欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

chx 学习jForum笔记十一 实现单点登录SSO

程序员文章站 2022-05-29 20:25:52
...

分为三部分:

1.导入原用户数据库.

2.修改SSO模块,实现登录认证.

3.实现新增用户.

 

从原表导入,使用以下SQL语句.可直接导入,也可加入\web-inf\config\database\sqlserver2000\sqlserver_2000_data_dump.sql

SET IDENTITY_INSERT jforum_users ON;
insert into jforum_users(user_id,username) select id+1000,emp_name from rswkbase;
update jforum_users set user_password = 'nopass',user_regdate = '2010-12-1' where user_password = ''
SET IDENTITY_INSERT jforum_users OFF;

初始库的导入是为了将原有的论坛内容转移至新论坛。

 

以下实现SSO功能。

 

修改SystemGlobals.properties

authentication.type = sso
sso.implementation = net.jforum.sso.RemoteUserSSO

由于原TOMCAT设置的request.getRemoteUser()中得到的是四位用户代码而不是用户名名,所以此处需要进行修改。

SSO模块修改.在net.jforum/sso/RemoteUserSSO.java中

else if (remoteUser != null && !remoteUser.equals(userSession.getUsername())) {

 改为

else if (remoteUser != null && !remoteUser.equals(String.valueOf(userSession.getUserId()))) {

 

在ControllerUtils.java中的checkSSO中新增

				if (!utils.userExists(username)) {
					final SessionContext session = JForumExecutionContext.getRequest().getSessionContext();

					String email = (String) session.getAttribute(SystemGlobals.getValue(ConfigKeys.SSO_EMAIL_ATTRIBUTE));
					String password = (String) session.getAttribute(SystemGlobals.getValue(ConfigKeys.SSO_PASSWORD_ATTRIBUTE));

					if (email == null) {
						email = SystemGlobals.getValue(ConfigKeys.SSO_DEFAULT_EMAIL);
					}

					if (password == null) {
						password = SystemGlobals.getValue(ConfigKeys.SSO_DEFAULT_PASSWORD);
					}

					utils.register(password, email);
				}
				

 改为

                boolean _flag = false;
                Integer userId=-1;
                try {
                    userId = Integer.parseInt(username);
                    _flag = utils.userExists(userId);
                } catch (Exception e){
                    _flag = utils.userExists(username);
                }
                if (!_flag) {
                    utils.register(userId);
                }
 

 

 

在SSOUtils.java中新增

    public boolean userExists(final Integer userId) //查询用户是否已注册
    {
        this.dao = DataAccessDriver.getInstance().newUserDAO();
        this.user = this.dao.selectByUserId(userId);
        this.exists = this.user != null;
        if (this.exists){
          this.username = this.user.getUsername();
        }
        return this.exists;
    }

在GenericUserDAO.java中新增

    public User selectByUserId(int userId)
    {
        PreparedStatement p = null;
        ResultSet rs = null;
        try {
            p = JForumExecutionContext.getConnection().prepareStatement(SystemGlobals.getSql("UserModel.selectByUserId"));
            p.setInt(1, userId);

            rs = p.executeQuery();
            User user = null;

            if (rs.next()) {
                user = new User();
                this.fillUserFromResultSet(user, rs);
            }

            return user;
        }
        catch (SQLException e) {
            throw new DatabaseException(e);
        }
        finally {
            DbUtils.close(rs, p);
        }
    }

 在UserDAO.java中新增

    User selectByUserId(int userId) ;
 

 

以下实现用户新增功能

在SSOUtils.java中新增

    public void register(final Integer userId) //新用户注册
    {
            // Is a new user for us. Register him
            this.user = new User();
            this.user.setId(userId);
            this.user.setUsername(getname(userId));
            this.user.setPassword(userId.toString());
            this.user.setEmail(getemail(userId));
            this.user.setActive(1);
            this.dao.addNewWithId(this.user);
            // Update the information
            ForumRepository.setLastRegisteredUser(this.user);  //设置最终注册用户
            ForumRepository.incrementTotalUsers(); //注册总人数加一
    }

 

   private String getname(final Integer userId){//从原数据表中获取用户名
        ResultSet resultSet = null;
        PreparedStatement pstmt = null;
        this.username = "null";
        try
        {
            pstmt = JForumExecutionContext.getConnection().prepareStatement(
                    SystemGlobals.getSql("UserState.getUsername"));
            pstmt.setInt(1, userId);

            resultSet = pstmt.executeQuery();
            if (resultSet.next()) {
                this.username = (resultSet.getString("emp_name"));
            }
        }
        catch (SQLException e)
        {
            throw new ForumException(e);
        }
        finally
        {
            DbUtils.close(resultSet, pstmt);
        }
     return this.username;
    }

 

   private String getemail(final Integer userId){//从原数据表中获取电子邮箱
        ResultSet resultSet = null;
        PreparedStatement pstmt = null;
        this.email = "null";
        try
        {
            pstmt = JForumExecutionContext.getConnection().prepareStatement(
                    SystemGlobals.getSql("UserState.getEmail"));
            pstmt.setInt(1, userId);

            resultSet = pstmt.executeQuery();
            if (resultSet.next()) {
                this.email = (resultSet.getString("mail"));
            }
        }
        catch (SQLException e)
        {
            throw new ForumException(e);
        }
        finally
        {
            DbUtils.close(resultSet, pstmt);
        }
        return this.email;
    }
 

在generic_queries.sql 中增加

UserModel.selectByUserId = SELECT * FROM jforum_users WHERE user_id = ?
UserState.getUsername = SELECT emp_name FROM rswkbase WHERE id = ?
UserState.getEmail = SELECT mail FROM chx_base_userstate WHERE user_id = ?

 这两句是从原有的数据表中取相应的内容。

 

 

 

ant dist