任意字符串的任意数量的脱敏算法
/**
* 中间截取两边扩散 适用于所有字符串
* @param str 未脱敏的字符串
* @param num 脱敏字符数量
* @return 脱敏后的字符串
*/
public static String handleStr(String str, int num) {
if (str == null || str.length() <= 1) {
return str;
}
int mid = str.length() / 2;
StringBuilder stringBuilder = new StringBuilder(str);
// 计数器
int c = 0;
int left = mid;
int right = mid - 1;
char tm = '*';
while (c < num) {
// 记住开始计数器
int ct = c;
// 处理前后两个字符
if (++right < str.length()) {
stringBuilder.setCharAt(right, tm);
c++;
}
if (c >= num) {
break;
}
if (--left >= 0) {
stringBuilder.setCharAt(left, tm);
c++;
}
// 如果c不变则也跳出循环
if (ct == c) {
break;
}
}
return stringBuilder.toString();
}
/**
* 这个默认值为4的 调用
* @param str 需要脱敏的字符串
* @return 脱敏后的字符串
*/
public static String handleStr(String str) {
return handleStr(str, 4);
}
/**
* 测试用例
**/
public static void main(String[] args) {
String[] mobiles = {"","1","22","333","4444","55555","666666","7777777","88888888","999999999","0000000000","18888888888"};
for (String mobile:mobiles) {
String all = handleStr(mobile, 4);
System.out.println(all);
}
}
执行结果,完全没问题,时间复杂度也控制在脱敏字符串长度,性能也很ok的,可能空间和代码写法还需要优化