| | |
| | | @Service |
| | | public class TokenService implements TokenMapper { |
| | | @Autowired |
| | | public RedisService redisService; |
| | | |
| | | @Autowired |
| | | TokenMapper tokenMapper; |
| | | |
| | | @Autowired |
| | |
| | | |
| | | @Autowired |
| | | LoginService loginService; |
| | | |
| | | @Autowired |
| | | RedisService redisService; |
| | | |
| | | @Override |
| | | public Integer selectCount(String name, Integer type) { |
| | |
| | | /** |
| | | * 获取新的令牌实体类 |
| | | */ |
| | | public TokenEntity getNewToken(int userid, HttpServletRequest req) { |
| | | public TokenEntity getNewToken(UserEntity ue, HttpServletRequest req) { |
| | | TokenEntity te = new TokenEntity(); |
| | | te.setToken(WebHelper.getGuid()); |
| | | te.setDuration(SettingData.TOKEN_EXPIRE); |
| | | te.setExpire(WebHelper.getTimestamp(SettingData.TOKEN_EXPIRE)); |
| | | te.setType(0); |
| | | te.setIp(WebHelper.getIpAddress(req)); |
| | | te.setCreateUser(userid); |
| | | te.setCreateUser(ue.getId()); |
| | | te.setUname(ue.getUname()); |
| | | |
| | | return te; |
| | | } |
| | |
| | | // 清除Cookie |
| | | WebHelper.deleteCookies(req, res); |
| | | |
| | | // 获取当前用户 |
| | | UserEntity ue = getCurrentUser(req); |
| | | if (ue == null) { |
| | | return false; |
| | | } |
| | | |
| | | // 清除缓存 |
| | | String tokenKey = RedisCacheKey.signTokenKey(token); |
| | | if (redisService.hasKey(tokenKey)) { |
| | |
| | | String userKey = RedisCacheKey.signUserKey(te.getToken()); |
| | | if (redisService.hasKey(userKey)) { |
| | | redisService.delete(userKey); |
| | | } |
| | | |
| | | // 获取当前用户 |
| | | UserEntity ue = getCurrentUser(req); |
| | | if (ue == null) { |
| | | return false; |
| | | } |
| | | |
| | | // db,设置令牌过期 |
| | |
| | | |
| | | // redis |
| | | Object obj = redisService.get(tokenKey); |
| | | if (obj != null && obj instanceof TokenEntity) { |
| | | if (obj instanceof TokenEntity) { |
| | | return (TokenEntity) obj; |
| | | } |
| | | |
| | |
| | | |
| | | // redis |
| | | Object obj = redisService.get(userKey); |
| | | if (obj != null && obj instanceof UserEntity) { |
| | | if (obj instanceof UserEntity) { |
| | | return (UserEntity) obj; |
| | | } |
| | | |
| | |
| | | |
| | | 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); |
| | | } |
| | | } |
| | | |
| | | /** |