| | |
| | | package com.lf.server.service.sys; |
| | | |
| | | import com.lf.server.entity.all.SettingData; |
| | | import com.lf.server.entity.sys.LoginEntity; |
| | | import com.lf.server.entity.sys.TokenEntity; |
| | | import com.lf.server.entity.sys.UserEntity; |
| | |
| | | import com.lf.server.helper.StringHelper; |
| | | import com.lf.server.helper.WebHelper; |
| | | import com.lf.server.mapper.sys.TokenMapper; |
| | | import com.lf.server.mapper.sys.UserMapper; |
| | | import com.lf.server.service.all.RedisService; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | |
| | | import javax.annotation.Resource; |
| | | import javax.servlet.http.HttpServletRequest; |
| | | import javax.servlet.http.HttpServletResponse; |
| | | import java.util.Date; |
| | |
| | | * @author sws |
| | | * @date 2022-09-28 |
| | | */ |
| | | |
| | | @Service |
| | | public class TokenService implements TokenMapper { |
| | | @Autowired |
| | | private RedisService redisService; |
| | | |
| | | @Autowired |
| | | @Resource |
| | | TokenMapper tokenMapper; |
| | | |
| | | @Autowired |
| | | UserService usersService; |
| | | @Resource |
| | | UserMapper userMapper; |
| | | |
| | | @Autowired |
| | | @Resource |
| | | LoginService loginService; |
| | | |
| | | @Resource |
| | | RedisService redisService; |
| | | |
| | | @Override |
| | | public Integer selectCount(String name, Integer type) { |
| | | return tokenMapper.selectCount(name,type); |
| | | name = StringHelper.getLikeUpperStr(name); |
| | | |
| | | return tokenMapper.selectCount(name, type); |
| | | } |
| | | |
| | | @Override |
| | | public List<TokenEntity> selectByPage(String name, Integer type, Integer limit, Integer offset) { |
| | | return tokenMapper.selectByPage(name,type, limit, offset); |
| | | name = StringHelper.getLikeUpperStr(name); |
| | | |
| | | return tokenMapper.selectByPage(name, type, limit, offset); |
| | | } |
| | | |
| | | @Override |
| | | public TokenEntity selectToken(int id) { |
| | | return tokenMapper.selectToken(id); |
| | | } |
| | | |
| | | @Override |
| | | public List<TokenEntity> selectByIds(List<Integer> ids) { |
| | | return tokenMapper.selectByIds(ids); |
| | | } |
| | | |
| | | @Override |
| | | public TokenEntity selectOneById(Integer id) { |
| | | return tokenMapper.selectOneById(id); |
| | | } |
| | | |
| | | @Override |
| | |
| | | |
| | | @Override |
| | | public Integer deleteToken(int id) { |
| | | TokenEntity entity = tokenMapper.selectToken(id); |
| | | if (null == entity) { |
| | | return 0; |
| | | } |
| | | |
| | | clearCache(entity.getToken()); |
| | | |
| | | return tokenMapper.deleteToken(id); |
| | | } |
| | | |
| | | @Override |
| | | public Integer deleteTokens(List<Integer> ids) { |
| | | List<TokenEntity> list = tokenMapper.selectByIds(ids); |
| | | if (null == list || list.isEmpty()) { |
| | | return 0; |
| | | } |
| | | |
| | | for (TokenEntity entity : list) { |
| | | clearCache(entity.getToken()); |
| | | } |
| | | |
| | | return tokenMapper.deleteTokens(ids); |
| | | } |
| | | |
| | |
| | | |
| | | @Override |
| | | public Integer updateTokenExpire(TokenEntity tokenEntity) { |
| | | clearCache(tokenEntity.getToken()); |
| | | |
| | | return tokenMapper.updateTokenExpire(tokenEntity); |
| | | } |
| | | |
| | | /** |
| | | * 获取新的令牌实体类 |
| | | * |
| | | * @param userid |
| | | * @param req |
| | | * @return |
| | | */ |
| | | public TokenEntity getNewToken(int userid, HttpServletRequest req) { |
| | | int duration = 240; |
| | | public TokenEntity getNewToken(UserEntity ue, HttpServletRequest req) { |
| | | return getNewToken(0, SettingData.TOKEN_EXPIRE, ue, req); |
| | | } |
| | | |
| | | /** |
| | | * 获取新的令牌实体类 |
| | | */ |
| | | public TokenEntity getNewToken(Integer type, Integer min, UserEntity ue, HttpServletRequest req) { |
| | | TokenEntity te = new TokenEntity(); |
| | | te.setToken(WebHelper.getGuid()); |
| | | te.setDuration(duration); |
| | | te.setExpire(WebHelper.getTimestamp(duration)); |
| | | te.setType(0); |
| | | te.setDuration(min); |
| | | te.setExpire(WebHelper.getTimestamp(min)); |
| | | te.setType(type); |
| | | te.setIp(WebHelper.getIpAddress(req)); |
| | | te.setCreateUser(userid); |
| | | |
| | | te.setCreateUser(ue.getId()); |
| | | te.setUname(ue.getUname()); |
| | | |
| | | return te; |
| | | } |
| | | |
| | | /** |
| | | * 是/否登录 |
| | | * |
| | | * @param req |
| | | * @param res |
| | | * @return |
| | | */ |
| | | public Boolean isLogin(HttpServletRequest req, HttpServletResponse res) { |
| | | String token = WebHelper.getToken(req); |
| | |
| | | return false; |
| | | } |
| | | |
| | | // redis |
| | | String tokenKey = RedisCacheKey.signTokenKey(token); |
| | | if (redisService.hasKey(tokenKey)) { |
| | | return true; |
| | | } |
| | | TokenEntity te = getEntityByToken(token); |
| | | |
| | | // db |
| | | TokenEntity te = selectOneByToken(token); |
| | | if (te != null) { |
| | | redisService.put(tokenKey, te, te.getDuration(), TimeUnit.MINUTES); |
| | | return true; |
| | | } |
| | | |
| | | return false; |
| | | return null != te; |
| | | } |
| | | |
| | | /** |
| | | * 登出 |
| | | * |
| | | * @param token |
| | | * @param req |
| | | * @return |
| | | */ |
| | | public Boolean logout(String token, HttpServletRequest req, HttpServletResponse res) { |
| | | TokenEntity te = getEntityByToken(token); |
| | | if (te == null) { |
| | | if (null == te) { |
| | | return false; |
| | | } |
| | | |
| | | // 清除Cookie WebHelper.saveCookie(StaticData.TOKEN_COOKIE_KEY, "", 60, res) |
| | | WebHelper.deleteAll(req, res); |
| | | // 清除Cookie |
| | | WebHelper.deleteCookies(req, res); |
| | | |
| | | // 获取当前用户 |
| | | UserEntity ue = getCurrentUser(req); |
| | |
| | | return false; |
| | | } |
| | | |
| | | // 清除缓存 |
| | | String tokenKey = RedisCacheKey.signTokenKey(token); |
| | | redisService.delete(tokenKey); |
| | | String userKey = RedisCacheKey.signUserKey(te.getToken()); |
| | | redisService.delete(userKey); |
| | | |
| | | // db,设置令牌过期 |
| | | te.setUpdateUser(ue.getId()); |
| | | Integer rows = updateTokenExpire(te); |
| | | if (rows == 0) { |
| | | if (0 == rows) { |
| | | return false; |
| | | } |
| | | |
| | | // 写日志 |
| | | LoginEntity le = loginService.getNewLogin(ue.getId(), 3, req); |
| | | LoginEntity le = loginService.getNewLogin(ue.getId(), 1, 3, 1, req); |
| | | rows = loginService.insertLogin(le); |
| | | |
| | | return rows > 0; |
| | | } |
| | | |
| | | /** |
| | | * 清除缓存 |
| | | */ |
| | | public void clearCache(String token) { |
| | | String tokenKey = RedisCacheKey.signTokenKey(token); |
| | | redisService.delete(tokenKey); |
| | | String userKey = RedisCacheKey.signUserKey(token); |
| | | redisService.delete(userKey); |
| | | } |
| | | |
| | | /** |
| | | * 根据令牌获取实体 |
| | | * |
| | | * @param token |
| | | * @return |
| | | */ |
| | | public TokenEntity getEntityByToken(String token) { |
| | | if (StringHelper.isNull(token)) { |
| | | return null; |
| | | } |
| | | |
| | | String tokenKey = RedisCacheKey.signTokenKey(token); |
| | | |
| | | // redis |
| | | Object obj = redisService.get(tokenKey); |
| | | if (obj != null && obj instanceof TokenEntity) { |
| | | if (obj instanceof TokenEntity) { |
| | | return (TokenEntity) obj; |
| | | } |
| | | |
| | | // db |
| | | TokenEntity te = selectOneByToken(token); |
| | | if (te != null) { |
| | | redisService.put(tokenKey, te, te.getDuration(), TimeUnit.MINUTES); |
| | | if (null != te) { |
| | | long min = StringHelper.getMinuteDifference(te.getExpire()); |
| | | if (min > 0) { |
| | | redisService.put(tokenKey, te, min, TimeUnit.MINUTES); |
| | | } |
| | | } |
| | | |
| | | return te; |
| | |
| | | |
| | | /** |
| | | * 保存token |
| | | * |
| | | * @param te |
| | | * @param req |
| | | * @param res |
| | | */ |
| | | public void saveToken(UserEntity ue, TokenEntity te, HttpServletRequest req, HttpServletResponse res) { |
| | | // 保存至Cookie |
| | |
| | | |
| | | /** |
| | | * 获取当前用户 |
| | | * |
| | | * @param req |
| | | * @return |
| | | */ |
| | | public UserEntity getCurrentUser(HttpServletRequest req) { |
| | | String token = WebHelper.getToken(req); |
| | | |
| | | return getUserByToken(token); |
| | | } |
| | | |
| | | /** |
| | | * 根据令牌获取用户 |
| | | */ |
| | | public UserEntity getUserByToken(String token) { |
| | | if (StringHelper.isNull(token)) { |
| | | return null; |
| | | } |
| | | |
| | | String userKey = RedisCacheKey.signUserKey(token); |
| | | |
| | | // redis |
| | | String userKey = RedisCacheKey.signUserKey(token); |
| | | Object obj = redisService.get(userKey); |
| | | if (obj != null && obj instanceof UserEntity) { |
| | | if (obj instanceof UserEntity) { |
| | | return (UserEntity) obj; |
| | | } |
| | | |
| | | // db |
| | | UserEntity ue = usersService.selectByToken(token); |
| | | if (ue != null) { |
| | | TokenEntity te = getEntityByToken(token); |
| | | if (te != null) { |
| | | redisService.put(userKey, ue, te.getDuration(), TimeUnit.MINUTES); |
| | | } |
| | | UserEntity ue = userMapper.selectByToken(token); |
| | | if (null != ue) { |
| | | getEntityByToken(token); |
| | | } |
| | | |
| | | return ue; |
| | | } |
| | | |
| | | /** |
| | | * 设置密码错误缓存 |
| | | */ |
| | | public void setPwdErrCache(UserEntity ue) { |
| | | String key = RedisCacheKey.signPwdError(ue.getUid()); |
| | | Object objCount = redisService.get(key); |
| | | |
| | | int count = objCount == null ? 1 : (int) objCount + 1; |
| | | redisService.put(key, count, SettingData.PWD_ERR_TIME, TimeUnit.MINUTES); |
| | | |
| | | // 记录日志 |
| | | HttpServletRequest req = WebHelper.getRequest(); |
| | | LoginEntity le = loginService.getNewLogin(ue.getId(), 1, 1, 0, req); |
| | | le.setDescr("密码不正确"); |
| | | loginService.insertLogin(le); |
| | | |
| | | if (count >= SettingData.PWD_ERR_COUNT) { |
| | | String token = WebHelper.getToken(req); |
| | | HttpServletResponse res = WebHelper.getResponse(); |
| | | logout(token, req, res); |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 用户ID是/否禁用 |
| | | */ |
| | | public boolean isUidDisable(UserEntity ue) { |
| | | String key = RedisCacheKey.signPwdError(ue.getUid()); |
| | | Object objCount = redisService.get(key); |
| | | |
| | | return null != objCount && (int) objCount >= SettingData.PWD_ERR_COUNT; |
| | | } |
| | | } |