增加阶梯封禁功能

This commit is contained in:
click33
2022-09-08 10:16:07 +08:00
parent 4d8e35208d
commit cb31c61efd
17 changed files with 903 additions and 289 deletions

View File

@@ -44,7 +44,7 @@ public class GlobalException {
}
else if(e instanceof DisableServiceException) { // 如果是被封禁异常
DisableServiceException ee = (DisableServiceException) e;
aj = AjaxJson.getNotJur("当前账号 " + ee.getService() + " 服务已被封禁:" + ee.getDisableTime() + "秒后解封");
aj = AjaxJson.getNotJur("当前账号 " + ee.getService() + " 服务已被封禁 (level=" + ee.getLevel() + ")" + ee.getDisableTime() + "秒后解封");
}
else { // 普通异常, 输出500 + 异常信息
aj = AjaxJson.getError(e.getMessage());

View File

@@ -60,7 +60,7 @@ public class StpUserUtil {
}
// =================== 获取token 相关 ===================
// ------------------- 获取token 相关 -------------------
/**
* 返回token名称
@@ -112,7 +112,7 @@ public class StpUserUtil {
}
// =================== 登录相关操作 ===================
// ------------------- 登录相关操作 -------------------
// --- 登录
@@ -357,7 +357,7 @@ public class StpUserUtil {
}
// =================== User-Session 相关 ===================
// ------------------- User-Session 相关 -------------------
/**
* 获取指定账号id的Session, 如果Session尚未创建isCreate=是否新建并返回
@@ -405,7 +405,7 @@ public class StpUserUtil {
}
// =================== Token-Session 相关 ===================
// ------------------- Token-Session 相关 -------------------
/**
* 获取指定Token-Session如果Session尚未创建则新建并返回
@@ -433,7 +433,7 @@ public class StpUserUtil {
}
// =================== [临时有效期] 验证相关 ===================
// ------------------- [临时有效期] 验证相关 -------------------
/**
* 检查当前token 是否已经[临时过期],如果已经过期则抛出异常
@@ -452,7 +452,7 @@ public class StpUserUtil {
}
// =================== 过期时间相关 ===================
// ------------------- 过期时间相关 -------------------
/**
* 获取当前登录者的 token 剩余有效时间 (单位: 秒)
@@ -503,7 +503,8 @@ public class StpUserUtil {
stpLogic.renewTimeout(tokenValue, timeout);
}
// =================== 角色验证操作 ===================
// ------------------- 角色验证操作 -------------------
/**
* 获取:当前账号的角色集合
@@ -584,7 +585,7 @@ public class StpUserUtil {
}
// =================== 权限验证操作 ===================
// ------------------- 权限验证操作 -------------------
/**
* 获取:当前账号的权限码集合
@@ -665,7 +666,7 @@ public class StpUserUtil {
}
// =================== id 反查token 相关操作 ===================
// ------------------- id 反查token 相关操作 -------------------
/**
* 获取指定账号id的tokenValue
@@ -718,7 +719,7 @@ public class StpUserUtil {
}
// =================== 会话管理 ===================
// ------------------- 会话管理 -------------------
/**
* 根据条件查询Token
@@ -763,47 +764,28 @@ public class StpUserUtil {
// ------------------- 账号封禁 -------------------
/**
* 封禁指定账号
* 封禁指定账号
* <p> 此方法不会直接将此账号id踢下线如需封禁后立即掉线请追加调用 StpUtil.logout(id)
*
* @param loginId 指定账号id
* @param disableTime 封禁时间, 单位: 秒 -1=永久封禁)
* @param time 封禁时间, 单位: 秒 -1=永久封禁)
*/
public static void disable(Object loginId, long disableTime) {
stpLogic.disable(loginId, disableTime);
public static void disable(Object loginId, long time) {
stpLogic.disable(loginId, time);
}
/**
* 封禁 指定账号 指定服务
* <p> 此方法不会直接将此账号id踢下线如需封禁后立即掉线请追加调用 StpUtil.logout(id)
* @param loginId 指定账号id
* @param service 指定服务
* @param disableTime 封禁时间, 单位: 秒 -1=永久封禁)
*/
public static void disable(Object loginId, String service, long disableTime) {
stpLogic.disable(loginId, service, disableTime);
}
/**
* 指定账号是否已被封禁 (true=已被封禁, false=未被封禁)
* 判断:指定账号是否已被封禁 (true=已被封禁, false=未被封禁)
*
* @param loginId 账号id
* @return see note
* @return /
*/
public static boolean isDisable(Object loginId) {
return stpLogic.isDisable(loginId);
}
/**
* 指定账号 指定服务 是否已被封禁 (true=已被封禁, false=未被封禁)
* @param loginId 账号id
* @param service 指定服务
* @return see note
*/
public static boolean isDisable(Object loginId, String service) {
return stpLogic.isDisable(loginId, service);
}
/**
* 校验指定账号是否已被封禁,如果被封禁则抛出异常
* 校验:指定账号是否已被封禁,如果被封禁则抛出异常
* @param loginId 账号id
*/
public static void checkDisable(Object loginId) {
@@ -811,25 +793,57 @@ public class StpUserUtil {
}
/**
* 校验 指定账号 指定服务 是否已被封禁,如果被封禁则抛出异常
* 获取:指定账号剩余封禁时间,单位:秒(-1=永久封禁,-2=未被封禁)
* @param loginId 账号id
* @param services 指定服务,可以指定多个
*/
public static void checkDisable(Object loginId, String... services) {
stpLogic.checkDisable(loginId, services);
}
/**
* 获取指定账号剩余封禁时间,单位:秒(-1=永久封禁,-2=未被封禁)
* @param loginId 账号id
* @return see note
* @return /
*/
public static long getDisableTime(Object loginId) {
return stpLogic.getDisableTime(loginId);
}
/**
* 获取 指定账号 指定服务 剩余封禁时间,单位:秒(-1=永久封禁,-2=未被封禁)
* 解封:指定账号
* @param loginId 账号id
*/
public static void untieDisable(Object loginId) {
stpLogic.untieDisable(loginId);
}
// ------------------- 分类封禁 -------------------
/**
* 封禁:指定账号的指定服务
* <p> 此方法不会直接将此账号id踢下线如需封禁后立即掉线请追加调用 StpUtil.logout(id)
* @param loginId 指定账号id
* @param service 指定服务
* @param time 封禁时间, 单位: 秒 -1=永久封禁)
*/
public static void disable(Object loginId, String service, long time) {
stpLogic.disable(loginId, service, time);
}
/**
* 判断:指定账号的指定服务 是否已被封禁 (true=已被封禁, false=未被封禁)
* @param loginId 账号id
* @param service 指定服务
* @return /
*/
public static boolean isDisable(Object loginId, String service) {
return stpLogic.isDisable(loginId, service);
}
/**
* 校验:指定账号 指定服务 是否已被封禁,如果被封禁则抛出异常
* @param loginId 账号id
* @param services 指定服务,可以指定多个
*/
public static void checkDisable(Object loginId, String... services) {
stpLogic.checkDisable(loginId, services);
}
/**
* 获取:指定账号 指定服务 剩余封禁时间,单位:秒(-1=永久封禁,-2=未被封禁)
* @param loginId 账号id
* @param service 指定服务
* @return see note
@@ -839,24 +853,105 @@ public class StpUserUtil {
}
/**
* 解封指定账号
* @param loginId 账号id
*/
public static void untieDisable(Object loginId) {
stpLogic.untieDisable(loginId);
}
/**
* 解封指定账号、指定服务
* 解封指定账号、指定服务
* @param loginId 账号id
* @param services 指定服务,可以指定多个
*/
public static void untieDisable(Object loginId, String... services) {
stpLogic.untieDisable(loginId, services);
}
// ------------------- 阶梯封禁 -------------------
/**
* 封禁:指定账号,并指定封禁等级
* @param loginId 指定账号id
* @param level 指定封禁等级
* @param time 封禁时间, 单位: 秒 -1=永久封禁)
*/
public static void disableLevel(Object loginId, int level, long time) {
stpLogic.disableLevel(loginId, level, time);
}
/**
* 封禁:指定账号的指定服务,并指定封禁等级
* @param loginId 指定账号id
* @param service 指定封禁服务
* @param level 指定封禁等级
* @param time 封禁时间, 单位: 秒 -1=永久封禁)
*/
public static void disableLevel(Object loginId, String service, int level, long time) {
stpLogic.disableLevel(loginId, service, level, time);
}
/**
* 判断:指定账号是否已被封禁到指定等级
*
* @param loginId 指定账号id
* @param level 指定封禁等级
* @return /
*/
public static boolean isDisableLevel(Object loginId, int level) {
return stpLogic.isDisableLevel(loginId, level);
}
/**
* 判断:指定账号的指定服务,是否已被封禁到指定等级
*
* @param loginId 指定账号id
* @param service 指定封禁服务
* @param level 指定封禁等级
* @return /
*/
public static boolean isDisableLevel(Object loginId, String service, int level) {
return stpLogic.isDisableLevel(loginId, service, level);
}
/**
* 校验:指定账号是否已被封禁到指定等级(如果已经达到,则抛出异常)
*
* @param loginId 指定账号id
* @param level 封禁等级 (只有 封禁等级 ≥ 此值 才会抛出异常)
*/
public static void checkDisableLevel(Object loginId, int level) {
stpLogic.checkDisableLevel(loginId, level);
}
/**
* 校验:指定账号的指定服务,是否已被封禁到指定等级(如果已经达到,则抛出异常)
*
* @param loginId 指定账号id
* @param service 指定封禁服务
* @param level 封禁等级 (只有 封禁等级 ≥ 此值 才会抛出异常)
*/
public static void checkDisableLevel(Object loginId, String service, int level) {
stpLogic.checkDisableLevel(loginId, service, level);
}
/**
* 获取:指定账号被封禁的等级,如果未被封禁则返回-2
*
* @param loginId 指定账号id
* @return /
*/
public static int getDisableLevel(Object loginId) {
return stpLogic.getDisableLevel(loginId);
}
/**
* 获取:指定账号的 指定服务 被封禁的等级,如果未被封禁则返回-2
*
* @param loginId 指定账号id
* @param service 指定封禁服务
* @return /
*/
public static int getDisableLevel(Object loginId, String service) {
return stpLogic.getDisableLevel(loginId, service);
}
// =================== 身份切换 ===================
// ------------------- 身份切换 -------------------
/**
* 临时切换身份为指定账号id

View File

@@ -60,7 +60,7 @@ public class StpUserUtil {
}
// =================== 获取token 相关 ===================
// ------------------- 获取token 相关 -------------------
/**
* 返回token名称
@@ -112,7 +112,7 @@ public class StpUserUtil {
}
// =================== 登录相关操作 ===================
// ------------------- 登录相关操作 -------------------
// --- 登录
@@ -357,7 +357,7 @@ public class StpUserUtil {
}
// =================== User-Session 相关 ===================
// ------------------- User-Session 相关 -------------------
/**
* 获取指定账号id的Session, 如果Session尚未创建isCreate=是否新建并返回
@@ -405,7 +405,7 @@ public class StpUserUtil {
}
// =================== Token-Session 相关 ===================
// ------------------- Token-Session 相关 -------------------
/**
* 获取指定Token-Session如果Session尚未创建则新建并返回
@@ -433,7 +433,7 @@ public class StpUserUtil {
}
// =================== [临时有效期] 验证相关 ===================
// ------------------- [临时有效期] 验证相关 -------------------
/**
* 检查当前token 是否已经[临时过期],如果已经过期则抛出异常
@@ -452,7 +452,7 @@ public class StpUserUtil {
}
// =================== 过期时间相关 ===================
// ------------------- 过期时间相关 -------------------
/**
* 获取当前登录者的 token 剩余有效时间 (单位: 秒)
@@ -503,7 +503,8 @@ public class StpUserUtil {
stpLogic.renewTimeout(tokenValue, timeout);
}
// =================== 角色验证操作 ===================
// ------------------- 角色验证操作 -------------------
/**
* 获取:当前账号的角色集合
@@ -584,7 +585,7 @@ public class StpUserUtil {
}
// =================== 权限验证操作 ===================
// ------------------- 权限验证操作 -------------------
/**
* 获取:当前账号的权限码集合
@@ -665,7 +666,7 @@ public class StpUserUtil {
}
// =================== id 反查token 相关操作 ===================
// ------------------- id 反查token 相关操作 -------------------
/**
* 获取指定账号id的tokenValue
@@ -718,7 +719,7 @@ public class StpUserUtil {
}
// =================== 会话管理 ===================
// ------------------- 会话管理 -------------------
/**
* 根据条件查询Token
@@ -763,47 +764,28 @@ public class StpUserUtil {
// ------------------- 账号封禁 -------------------
/**
* 封禁指定账号
* 封禁指定账号
* <p> 此方法不会直接将此账号id踢下线如需封禁后立即掉线请追加调用 StpUtil.logout(id)
*
* @param loginId 指定账号id
* @param disableTime 封禁时间, 单位: 秒 -1=永久封禁)
* @param time 封禁时间, 单位: 秒 -1=永久封禁)
*/
public static void disable(Object loginId, long disableTime) {
stpLogic.disable(loginId, disableTime);
public static void disable(Object loginId, long time) {
stpLogic.disable(loginId, time);
}
/**
* 封禁 指定账号 指定服务
* <p> 此方法不会直接将此账号id踢下线如需封禁后立即掉线请追加调用 StpUtil.logout(id)
* @param loginId 指定账号id
* @param service 指定服务
* @param disableTime 封禁时间, 单位: 秒 -1=永久封禁)
*/
public static void disable(Object loginId, String service, long disableTime) {
stpLogic.disable(loginId, service, disableTime);
}
/**
* 指定账号是否已被封禁 (true=已被封禁, false=未被封禁)
* 判断:指定账号是否已被封禁 (true=已被封禁, false=未被封禁)
*
* @param loginId 账号id
* @return see note
* @return /
*/
public static boolean isDisable(Object loginId) {
return stpLogic.isDisable(loginId);
}
/**
* 指定账号 指定服务 是否已被封禁 (true=已被封禁, false=未被封禁)
* @param loginId 账号id
* @param service 指定服务
* @return see note
*/
public static boolean isDisable(Object loginId, String service) {
return stpLogic.isDisable(loginId, service);
}
/**
* 校验指定账号是否已被封禁,如果被封禁则抛出异常
* 校验:指定账号是否已被封禁,如果被封禁则抛出异常
* @param loginId 账号id
*/
public static void checkDisable(Object loginId) {
@@ -811,25 +793,57 @@ public class StpUserUtil {
}
/**
* 校验 指定账号 指定服务 是否已被封禁,如果被封禁则抛出异常
* 获取:指定账号剩余封禁时间,单位:秒(-1=永久封禁,-2=未被封禁)
* @param loginId 账号id
* @param services 指定服务,可以指定多个
*/
public static void checkDisable(Object loginId, String... services) {
stpLogic.checkDisable(loginId, services);
}
/**
* 获取指定账号剩余封禁时间,单位:秒(-1=永久封禁,-2=未被封禁)
* @param loginId 账号id
* @return see note
* @return /
*/
public static long getDisableTime(Object loginId) {
return stpLogic.getDisableTime(loginId);
}
/**
* 获取 指定账号 指定服务 剩余封禁时间,单位:秒(-1=永久封禁,-2=未被封禁)
* 解封:指定账号
* @param loginId 账号id
*/
public static void untieDisable(Object loginId) {
stpLogic.untieDisable(loginId);
}
// ------------------- 分类封禁 -------------------
/**
* 封禁:指定账号的指定服务
* <p> 此方法不会直接将此账号id踢下线如需封禁后立即掉线请追加调用 StpUtil.logout(id)
* @param loginId 指定账号id
* @param service 指定服务
* @param time 封禁时间, 单位: 秒 -1=永久封禁)
*/
public static void disable(Object loginId, String service, long time) {
stpLogic.disable(loginId, service, time);
}
/**
* 判断:指定账号的指定服务 是否已被封禁 (true=已被封禁, false=未被封禁)
* @param loginId 账号id
* @param service 指定服务
* @return /
*/
public static boolean isDisable(Object loginId, String service) {
return stpLogic.isDisable(loginId, service);
}
/**
* 校验:指定账号 指定服务 是否已被封禁,如果被封禁则抛出异常
* @param loginId 账号id
* @param services 指定服务,可以指定多个
*/
public static void checkDisable(Object loginId, String... services) {
stpLogic.checkDisable(loginId, services);
}
/**
* 获取:指定账号 指定服务 剩余封禁时间,单位:秒(-1=永久封禁,-2=未被封禁)
* @param loginId 账号id
* @param service 指定服务
* @return see note
@@ -839,24 +853,105 @@ public class StpUserUtil {
}
/**
* 解封指定账号
* @param loginId 账号id
*/
public static void untieDisable(Object loginId) {
stpLogic.untieDisable(loginId);
}
/**
* 解封指定账号、指定服务
* 解封指定账号、指定服务
* @param loginId 账号id
* @param services 指定服务,可以指定多个
*/
public static void untieDisable(Object loginId, String... services) {
stpLogic.untieDisable(loginId, services);
}
// ------------------- 阶梯封禁 -------------------
/**
* 封禁:指定账号,并指定封禁等级
* @param loginId 指定账号id
* @param level 指定封禁等级
* @param time 封禁时间, 单位: 秒 -1=永久封禁)
*/
public static void disableLevel(Object loginId, int level, long time) {
stpLogic.disableLevel(loginId, level, time);
}
/**
* 封禁:指定账号的指定服务,并指定封禁等级
* @param loginId 指定账号id
* @param service 指定封禁服务
* @param level 指定封禁等级
* @param time 封禁时间, 单位: 秒 -1=永久封禁)
*/
public static void disableLevel(Object loginId, String service, int level, long time) {
stpLogic.disableLevel(loginId, service, level, time);
}
/**
* 判断:指定账号是否已被封禁到指定等级
*
* @param loginId 指定账号id
* @param level 指定封禁等级
* @return /
*/
public static boolean isDisableLevel(Object loginId, int level) {
return stpLogic.isDisableLevel(loginId, level);
}
/**
* 判断:指定账号的指定服务,是否已被封禁到指定等级
*
* @param loginId 指定账号id
* @param service 指定封禁服务
* @param level 指定封禁等级
* @return /
*/
public static boolean isDisableLevel(Object loginId, String service, int level) {
return stpLogic.isDisableLevel(loginId, service, level);
}
/**
* 校验:指定账号是否已被封禁到指定等级(如果已经达到,则抛出异常)
*
* @param loginId 指定账号id
* @param level 封禁等级 (只有 封禁等级 ≥ 此值 才会抛出异常)
*/
public static void checkDisableLevel(Object loginId, int level) {
stpLogic.checkDisableLevel(loginId, level);
}
/**
* 校验:指定账号的指定服务,是否已被封禁到指定等级(如果已经达到,则抛出异常)
*
* @param loginId 指定账号id
* @param service 指定封禁服务
* @param level 封禁等级 (只有 封禁等级 ≥ 此值 才会抛出异常)
*/
public static void checkDisableLevel(Object loginId, String service, int level) {
stpLogic.checkDisableLevel(loginId, service, level);
}
/**
* 获取:指定账号被封禁的等级,如果未被封禁则返回-2
*
* @param loginId 指定账号id
* @return /
*/
public static int getDisableLevel(Object loginId) {
return stpLogic.getDisableLevel(loginId);
}
/**
* 获取:指定账号的 指定服务 被封禁的等级,如果未被封禁则返回-2
*
* @param loginId 指定账号id
* @param service 指定封禁服务
* @return /
*/
public static int getDisableLevel(Object loginId, String service) {
return stpLogic.getDisableLevel(loginId, service);
}
// =================== 身份切换 ===================
// ------------------- 身份切换 -------------------
/**
* 临时切换身份为指定账号id