管道基础大数据平台系统开发-【后端】-Server
13693261870
2023-02-14 05ffa1a7f490e1e81d6fbf1ee948db50b1fff6fc
src/main/java/com/lf/server/service/sys/UserService.java
@@ -1,19 +1,18 @@
package com.lf.server.service.sys;
import com.lf.server.entity.all.RedisCacheKey;
import com.lf.server.entity.all.SettingData;
import com.lf.server.entity.sys.RoleEntity;
import com.lf.server.entity.sys.UserEntity;
import com.lf.server.helper.Md5Helper;
import com.lf.server.helper.RsaHelper;
import com.lf.server.helper.StringHelper;
import com.lf.server.mapper.sys.UserMapper;
import com.lf.server.service.all.RedisService;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.cache.RedisCache;
import org.springframework.stereotype.Service;
import java.util.List;
import java.util.concurrent.TimeUnit;
/**
 * 用户表
@@ -29,11 +28,20 @@
    @Autowired
    RedisService redisService;
    @Override
    public Integer selectCount(String uname) {
        uname = StringHelper.getLikeStr(uname);
    @Autowired
    LoginService loginService;
        return userMapper.selectCount(uname);
    @Autowired
    TokenService tokenService;
    private final static Log log = LogFactory.getLog(UserService.class);
    @Override
    public Integer selectCount(String uname, String depcode) {
        uname = StringHelper.getLikeStr(uname);
        depcode = StringHelper.getLeftLike(depcode);
        return userMapper.selectCount(uname, depcode);
    }
    @Override
@@ -52,15 +60,36 @@
    }
    @Override
    public List<UserEntity> selectByPage(String uname, Integer limit, Integer offset) {
    public List<UserEntity> selectByPage(String uname, String depcode, Integer limit, Integer offset) {
        uname = StringHelper.getLikeStr(uname);
        depcode = StringHelper.getLeftLike(depcode);
        return userMapper.selectByPage(uname, limit, offset);
        return userMapper.selectByPage(uname, depcode, limit, offset);
    }
    @Override
    public UserEntity selectByToken(String token) {
        return userMapper.selectByToken(token);
    }
    @Override
    public Integer selectForIsAdmin(Integer id) {
        return userMapper.selectForIsAdmin(id);
    }
    @Override
    public List<UserEntity> selectAdminUsers(Integer type) {
        return userMapper.selectAdminUsers(type);
    }
    @Override
    public List<RoleEntity> selectRoleByUserId(Integer id) {
        return userMapper.selectRoleByUserId(id);
    }
    @Override
    public List<UserEntity> selectUserByRoleId(Integer roleId) {
        return userMapper.selectUserByRoleId(roleId);
    }
    @Override
@@ -84,22 +113,24 @@
    }
    @Override
    public Integer updateUsers(UserEntity userEntity) {
        return userMapper.updateUsers(userEntity);
    public Integer updateUser(UserEntity userEntity) {
        return userMapper.updateUser(userEntity);
    }
    @Override
    public Integer selectCountForRole(String uname, Integer roleid, Integer depid) {
    public Integer selectCountForRole(String uname, Integer roleid, String depcode) {
        uname = StringHelper.getLikeStr(uname);
        depcode = StringHelper.getLeftLike(depcode);
        return userMapper.selectCountForRole(uname, roleid, depid);
        return userMapper.selectCountForRole(uname, roleid, depcode);
    }
    @Override
    public List<UserEntity> selectByPageForRole(String uname, Integer roleid, Integer depid, Integer limit, Integer offset) {
    public List<UserEntity> selectByPageForRole(String uname, Integer roleid, String depcode, Integer limit, Integer offset) {
        uname = StringHelper.getLikeStr(uname);
        depcode = StringHelper.getLeftLike(depcode);
        return userMapper.selectByPageForRole(uname, roleid, depid, limit, offset);
        return userMapper.selectByPageForRole(uname, roleid, depcode, limit, offset);
    }
    @Override
@@ -125,9 +156,9 @@
    }
    /**
     * 验证新用户密码
     * 验证登录用户密码
     */
    public String validateNewPwd(UserEntity entity) {
    public String validateLoginPwd(UserEntity entity) {
        try {
            String str = validateUserEntity(entity);
            if (str != null) {
@@ -137,17 +168,47 @@
            // 解密
            String uid = RsaHelper.decrypt(entity.getUid());
            String pwd = RsaHelper.decrypt(entity.getPwd());
            if (!StringHelper.checkPwdValid(pwd)) {
            entity.setUid(uid);
            entity.setPwd(pwd);
            if (tokenService.isUidDisable(entity)) {
                return "用户ID已禁用";
            }
            return null;
        } catch (Exception ex) {
            log.error(ex.getMessage(), ex);
            return "解密失败";
        }
    }
    /**
     * 验证新用户密码
     */
    @SuppressWarnings("AlibabaRemoveCommentedCode")
    public String validateNewPwd(UserEntity entity) {
        try {
            String str = validateUserEntity(entity);
            if (str != null) {
                return str;
            }
            // 解密
            String uid = RsaHelper.decrypt(entity.getUid());
            /*String pwd = RsaHelper.decrypt(entity.getPwd());
            if (!StringHelper.isPwdValid(pwd)) {
                return "密码不符合要求";
            }
            String newPwd = Md5Helper.reverse(Md5Helper.generate(pwd));
            entity.setPwd(newPwd);
            entity.setPwd(newPwd);*/
            entity.setUid(uid);
            return null;
        } catch (Exception ex) {
            return "密码解密失败";
            log.error(ex.getMessage(), ex);
            return "解密失败";
        }
    }
@@ -173,10 +234,10 @@
                return "没有找到用户";
            }
            if (!Md5Helper.validatePassword(pwd, ue.getPwd())) {
                //
                return "旧密码输入错误";
                tokenService.setPwdErrCache(ue);
                return "旧密码不正确";
            }
            if (!StringHelper.checkPwdValid(salt)) {
            if (StringHelper.isPwdInvalid(salt)) {
                return "密码不符合要求";
            }
@@ -187,7 +248,8 @@
            return null;
        } catch (Exception ex) {
            return "密码解密失败";
            log.error(ex.getMessage(), ex);
            return "解密失败";
        }
    }
@@ -205,12 +267,13 @@
        try {
            String pwd = RsaHelper.decrypt(adminPwd);
            if (!Md5Helper.validatePassword(pwd, ue.getPwd())) {
                tokenService.setPwdErrCache(ue);
                return "管理员密码不正确";
            }
            return null;
        } catch (Exception ex) {
            return "密码解密失败";
            return "解密失败";
        }
    }
@@ -224,7 +287,7 @@
        try {
            String pwd = RsaHelper.decrypt(newPwd);
            if (!StringHelper.checkPwdValid(pwd)) {
            if (StringHelper.isPwdInvalid(pwd)) {
                return "密码不符合要求";
            }
@@ -233,7 +296,8 @@
            return null;
        } catch (Exception ex) {
            return "密码解密失败";
            log.error(ex.getMessage(), ex);
            return "解密失败";
        }
    }
}