mirror of
https://github.com/dromara/RuoYi-Vue-Plus.git
synced 2025-12-27 02:25:59 +08:00
update 增加高安全脱敏方法
This commit is contained in:
@@ -28,19 +28,60 @@ public class DesensitizedUtils extends DesensitizedUtil {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int len = value.length();
|
int len = value.length();
|
||||||
|
int prefixMaskLimit = prefixVisible + maskLength;
|
||||||
|
int fullLimit = prefixMaskLimit + suffixVisible;
|
||||||
|
|
||||||
// 总长度小于等于前后可见长度 → 全部掩码
|
// 规则 1:长度 <= 中间掩码长度 → 全掩码
|
||||||
if (len <= prefixVisible + suffixVisible) {
|
if (len <= maskLength) {
|
||||||
return StrUtil.repeat('*', len);
|
return StrUtil.repeat('*', len);
|
||||||
}
|
}
|
||||||
|
String mask = StrUtil.repeat('*', maskLength);
|
||||||
|
|
||||||
|
// 规则 2:长度 <= 前缀 + 中间掩码
|
||||||
|
if (len <= prefixMaskLimit) {
|
||||||
|
return value.substring(0, len - maskLength) + mask;
|
||||||
|
}
|
||||||
|
|
||||||
String prefix = value.substring(0, prefixVisible);
|
String prefix = value.substring(0, prefixVisible);
|
||||||
String suffix = value.substring(len - suffixVisible);
|
|
||||||
// 中间可用于脱敏的最大长度
|
// 规则 3:长度 <= 前缀 + 中间掩码 + 后缀
|
||||||
int middleLen = len - prefixVisible - suffixVisible;
|
if (len <= fullLimit) {
|
||||||
// 实际掩码长度 至少脱敏 1 位
|
int suffixLen = len - prefixMaskLimit;
|
||||||
int actualMaskLen = Math.max(1, Math.min(maskLength, middleLen));
|
return prefix + mask + value.substring(len - suffixLen);
|
||||||
return prefix + StrUtil.repeat('*', actualMaskLen) + suffix;
|
}
|
||||||
|
|
||||||
|
// 规则 4:标准形态
|
||||||
|
return prefix + mask + value.substring(len - suffixVisible);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 高安全级别脱敏方法(Token / 私钥)
|
||||||
|
*
|
||||||
|
* @param value 原始字符串
|
||||||
|
* @param prefixVisible 前面可见长度(推荐0~4)
|
||||||
|
* @param suffixVisible 后面可见长度(推荐0~4)
|
||||||
|
* @return 脱敏后字符串
|
||||||
|
*/
|
||||||
|
public static String maskHighSecurity(String value, int prefixVisible, int suffixVisible) {
|
||||||
|
if (StrUtil.isBlank(value)) {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
int len = value.length();
|
||||||
|
|
||||||
|
// 规则1:长度 <= 前缀可见长度 → 全部掩码
|
||||||
|
if (len <= prefixVisible) {
|
||||||
|
return StrUtil.repeat('*', len);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 规则2:长度 <= 前缀 + 后缀可见长度 → 优先掩码后面
|
||||||
|
if (len <= prefixVisible + suffixVisible) {
|
||||||
|
return value.substring(0, len - prefixVisible) + StrUtil.repeat('*', prefixVisible);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 规则3:标准形态 → 前后可见,中间全部掩码
|
||||||
|
return value.substring(0, prefixVisible)
|
||||||
|
+ StrUtil.repeat('*', len - prefixVisible - suffixVisible)
|
||||||
|
+ value.substring(len - suffixVisible);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -88,6 +88,11 @@ public enum SensitiveStrategy {
|
|||||||
*/
|
*/
|
||||||
STRING_MASK(s -> DesensitizedUtils.mask(s, 4, 4, 4)),
|
STRING_MASK(s -> DesensitizedUtils.mask(s, 4, 4, 4)),
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 高安全级别脱敏(Token / 私钥):前2位可见,后2位可见,中间全部掩码
|
||||||
|
*/
|
||||||
|
MASK_HIGH_SECURITY(s -> DesensitizedUtils.maskHighSecurity(s, 2, 2)),
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 清空为""
|
* 清空为""
|
||||||
*/
|
*/
|
||||||
|
|||||||
Reference in New Issue
Block a user