1
0
mirror of synced 2026-05-22 22:53:16 +00:00

使动态 active-timeout 支持 -1 值

This commit is contained in:
click33
2023-06-08 11:43:01 +08:00
parent 3626c490b8
commit 30352742f6
3 changed files with 9 additions and 7 deletions
@@ -1617,13 +1617,12 @@ public class StpLogic {
String key = splicingKeyLastActiveTime(tokenValue);
String lastActiveTimeString = getSaTokenDao().get(key);
// 2、如果查不到,返回-2
if(lastActiveTimeString == null) {
return SaTokenDao.NOT_VALUE_EXPIRE;
}
// 3、计算最后活跃时间 距离 此时此刻 的时间差
// 3、计算最后活跃时间 距离 此时此刻 的时间差
// 计算公式为: (当前时间 - 最后活跃时间) / 1000
SaValue2Box box = new SaValue2Box(lastActiveTimeString);
long lastActiveTime = box.getValue1AsLong();
@@ -1631,6 +1630,10 @@ public class StpLogic {
long timeDiff = (System.currentTimeMillis() - lastActiveTime) / 1000;
// 该 token 允许的时间差
long allowTimeDiff = getTokenUseActiveTimeoutOrGlobalConfig(tokenValue);
if(allowTimeDiff == SaTokenDao.NEVER_EXPIRE) {
// 如果允许的时间差为 -1 ,则代表永不冻结,此处需要立即返回 -1 ,无需后续计算
return SaTokenDao.NEVER_EXPIRE;
}
// 4、校验这个时间差是否超过了允许的值
// 计算公式为: 允许的最大时间差 - 实际时间差,判断是否 < 0, 如果是则代表已经被冻结 ,返回-2
@@ -2783,7 +2786,8 @@ public class StpLogic {
* @return /
*/
public boolean isOpenCheckActiveTimeout() {
return getConfigOrGlobal().getActiveTimeout() != SaTokenDao.NEVER_EXPIRE;
SaTokenConfig cfg = getConfigOrGlobal();
return cfg.getActiveTimeout() != SaTokenDao.NEVER_EXPIRE || cfg.getDynamicActiveTimeout();
}
/**
@@ -21,7 +21,6 @@ import cn.dev33.satoken.listener.SaTokenEventCenter;
import cn.dev33.satoken.session.SaSession;
import cn.dev33.satoken.session.TokenSign;
import java.util.Collections;
import java.util.List;
/**
@@ -4,7 +4,6 @@ import cn.dev33.satoken.stp.SaLoginConfig;
import cn.dev33.satoken.stp.StpUtil;
import cn.dev33.satoken.util.SaFoxUtil;
import cn.dev33.satoken.util.SaResult;
import com.pj.satoken.StpUserUtil;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
@@ -23,7 +22,7 @@ public class TestController {
// 测试登录 ---- http://localhost:8081/test/login
@RequestMapping("login")
public SaResult login(@RequestParam(defaultValue = "10001") long id) {
StpUtil.login(id, SaLoginConfig.setActiveTimeout(1000));
StpUtil.login(id, SaLoginConfig.setActiveTimeout(-1));
return SaResult.ok("登录成功");
}
@@ -31,7 +30,7 @@ public class TestController {
@RequestMapping("test")
public SaResult test() {
System.out.println("------------进来了 " + SaFoxUtil.formatDate(new Date()));
StpUserUtil.login(10001, SaLoginConfig.setActiveTimeout(2000));
StpUtil.getLoginId();
// 返回
return SaResult.data(null);
}