|
|
|
|
@ -1,14 +1,5 @@
|
|
|
|
|
package com.da.framework.web.service;
|
|
|
|
|
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
|
import java.util.Map;
|
|
|
|
|
import java.util.concurrent.TimeUnit;
|
|
|
|
|
import javax.servlet.http.HttpServletRequest;
|
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
|
import org.springframework.beans.factory.annotation.Value;
|
|
|
|
|
import org.springframework.stereotype.Component;
|
|
|
|
|
import com.da.common.constant.CacheConstants;
|
|
|
|
|
import com.da.common.constant.Constants;
|
|
|
|
|
import com.da.common.core.domain.model.LoginUser;
|
|
|
|
|
@ -22,6 +13,16 @@ import eu.bitwalker.useragentutils.UserAgent;
|
|
|
|
|
import io.jsonwebtoken.Claims;
|
|
|
|
|
import io.jsonwebtoken.Jwts;
|
|
|
|
|
import io.jsonwebtoken.SignatureAlgorithm;
|
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
|
import org.springframework.beans.factory.annotation.Value;
|
|
|
|
|
import org.springframework.stereotype.Component;
|
|
|
|
|
|
|
|
|
|
import javax.servlet.http.HttpServletRequest;
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
|
import java.util.Map;
|
|
|
|
|
import java.util.concurrent.TimeUnit;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* token验证处理
|
|
|
|
|
@ -33,6 +34,10 @@ public class TokenService
|
|
|
|
|
{
|
|
|
|
|
private static final Logger log = LoggerFactory.getLogger(TokenService.class);
|
|
|
|
|
|
|
|
|
|
// 是否允许账户多终端同时登录(true允许 false不允许)
|
|
|
|
|
@Value("${token.soloLogin}")
|
|
|
|
|
private boolean soloLogin;
|
|
|
|
|
|
|
|
|
|
// 令牌自定义标识
|
|
|
|
|
@Value("${token.header}")
|
|
|
|
|
private String header;
|
|
|
|
|
@ -96,15 +101,29 @@ public class TokenService
|
|
|
|
|
/**
|
|
|
|
|
* 删除用户身份信息
|
|
|
|
|
*/
|
|
|
|
|
public void delLoginUser(String token)
|
|
|
|
|
/* public void delLoginUser(String token)
|
|
|
|
|
{
|
|
|
|
|
if (StringUtils.isNotEmpty(token))
|
|
|
|
|
{
|
|
|
|
|
String userKey = getTokenKey(token);
|
|
|
|
|
redisCache.deleteObject(userKey);
|
|
|
|
|
}
|
|
|
|
|
}*/
|
|
|
|
|
public void delLoginUser(String token, Long userId)
|
|
|
|
|
{
|
|
|
|
|
if (StringUtils.isNotEmpty(token))
|
|
|
|
|
{
|
|
|
|
|
String userKey = getTokenKey(token);
|
|
|
|
|
redisCache.deleteObject(userKey);
|
|
|
|
|
}
|
|
|
|
|
if (!soloLogin && StringUtils.isNotNull(userId))
|
|
|
|
|
{
|
|
|
|
|
String userIdKey = getUserIdKey(userId);
|
|
|
|
|
redisCache.deleteObject(userIdKey);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 创建令牌
|
|
|
|
|
*
|
|
|
|
|
@ -144,13 +163,28 @@ public class TokenService
|
|
|
|
|
*
|
|
|
|
|
* @param loginUser 登录信息
|
|
|
|
|
*/
|
|
|
|
|
public void refreshToken(LoginUser loginUser)
|
|
|
|
|
/* public void refreshToken(LoginUser loginUser)
|
|
|
|
|
{
|
|
|
|
|
loginUser.setLoginTime(System.currentTimeMillis());
|
|
|
|
|
loginUser.setExpireTime(loginUser.getLoginTime() + expireTime * MILLIS_MINUTE);
|
|
|
|
|
// 根据uuid将loginUser缓存
|
|
|
|
|
String userKey = getTokenKey(loginUser.getToken());
|
|
|
|
|
redisCache.setCacheObject(userKey, loginUser, expireTime, TimeUnit.MINUTES);
|
|
|
|
|
}*/
|
|
|
|
|
public String refreshToken(LoginUser loginUser)
|
|
|
|
|
{
|
|
|
|
|
loginUser.setLoginTime(System.currentTimeMillis());
|
|
|
|
|
loginUser.setExpireTime(loginUser.getLoginTime() + expireTime * MILLIS_MINUTE);
|
|
|
|
|
// 根据uuid将loginUser缓存
|
|
|
|
|
String userKey = getTokenKey(loginUser.getToken());
|
|
|
|
|
redisCache.setCacheObject(userKey, loginUser, expireTime, TimeUnit.MINUTES);
|
|
|
|
|
if (!soloLogin)
|
|
|
|
|
{
|
|
|
|
|
// 缓存用户唯一标识,防止同一帐号,同时登录
|
|
|
|
|
String userIdKey = getUserIdKey(loginUser.getUser().getUserId());
|
|
|
|
|
redisCache.setCacheObject(userIdKey, userKey, expireTime, TimeUnit.MINUTES);
|
|
|
|
|
}
|
|
|
|
|
return userKey;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
@ -168,6 +202,11 @@ public class TokenService
|
|
|
|
|
loginUser.setOs(userAgent.getOperatingSystem().getName());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private String getUserIdKey(Long userId)
|
|
|
|
|
{
|
|
|
|
|
return Constants.LOGIN_USERID_KEY + userId;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 从数据声明生成令牌
|
|
|
|
|
*
|
|
|
|
|
|