code review 脱敏组件的代码

pull/2/head
YunaiV 2023-01-17 08:11:57 +08:00
parent e5ab9b71b6
commit 32d7d6ab29
7 changed files with 26 additions and 13 deletions

View File

@ -9,8 +9,11 @@
<version>${revision}</version> <version>${revision}</version>
</parent> </parent>
<!-- TODO 城yudao-spring-boot-starter-biz-desensitize =》yudao-spring-boot-starter-desensitize不属于业务哈 -->
<artifactId>yudao-spring-boot-starter-biz-desensitize</artifactId> <artifactId>yudao-spring-boot-starter-biz-desensitize</artifactId>
<!-- TODO 城:这个组件的说明; -->
<!-- TODO 城:这里去掉哈 -->
<properties> <properties>
<maven.compiler.source>11</maven.compiler.source> <maven.compiler.source>11</maven.compiler.source>
<maven.compiler.target>11</maven.compiler.target> <maven.compiler.target>11</maven.compiler.target>

View File

@ -8,14 +8,17 @@ import cn.iocoder.yudao.framework.desensitize.core.slider.handler.DefaultDesensi
import java.util.Map; import java.util.Map;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
// TODO @城DesensitizationHandlerHolder =》 DesensitizationHandlerFactory Holder 没有太多工厂的味道哈
/** /**
* Holder * Holder
*/ */
public class DesensitizationHandlerHolder { public class DesensitizationHandlerHolder {
/** /**
* handler * handler
*/ */
private static final Map<Class<? extends DesensitizationHandler>, DesensitizationHandler> HANDLER_MAP = new ConcurrentHashMap<>() {{ private static final Map<Class<? extends DesensitizationHandler>, DesensitizationHandler> HANDLER_MAP = new ConcurrentHashMap<>() {{
// TODO @城:这 2 个,是不是不用呀?需要的时候初始化
put(DefaultRegexDesensitizationHandler.class, new DefaultRegexDesensitizationHandler()); put(DefaultRegexDesensitizationHandler.class, new DefaultRegexDesensitizationHandler());
put(DefaultDesensitizationHandler.class, new DefaultDesensitizationHandler()); put(DefaultDesensitizationHandler.class, new DefaultDesensitizationHandler());
}}; }};

View File

@ -11,19 +11,21 @@ import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy; import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target; import java.lang.annotation.Target;
// TODO @城每个接口上author 写下哈。
// TODO @城Desensitize = 》DesensitizeBy
// TODO @城Desensitize 类注释,方便读者阅读理解
/** /**
* Desensitize * Desensitize
*/ */
@Documented @Documented
@Target({ ElementType.ANNOTATION_TYPE}) @Target(ElementType.ANNOTATION_TYPE)
@Retention(RetentionPolicy.RUNTIME) @Retention(RetentionPolicy.RUNTIME)
@JacksonAnnotationsInside @JacksonAnnotationsInside // TODO @城:这个的作用,也可以写下
@JsonSerialize(using = StringDesensitizeSerializer.class) @JsonSerialize(using = StringDesensitizeSerializer.class) // TODO @城:这个的作用,也可以写下
public @interface Desensitize { public @interface Desensitize {
/** /**
* *
*/ */
Class<? extends DesensitizationHandler> desensitizationBy(); Class<? extends DesensitizationHandler> desensitizationBy(); // TODO @城desensitizationBy -> handler
} }

View File

@ -11,7 +11,7 @@ public interface DesensitizationHandler<T extends Annotation> {
* *
* *
* @param origin * @param origin
* @param anno * @param anno // TODO 不要这样的缩写哈anno -> annotation
* @return * @return
*/ */
String desensitize(String origin, T anno); String desensitize(String origin, T anno);

View File

@ -15,6 +15,8 @@ public abstract class AbstractRegexDesensitizationHandler<T extends Annotation>
return origin.replaceAll(regex, replacer); return origin.replaceAll(regex, replacer);
} }
// TODO @城:是不是抽象两个方法,一个拿 regex一个拿 replacer
/** /**
* *
* *

View File

@ -12,25 +12,26 @@ public abstract class AbstractDesensitizationHandler<T extends Annotation> imple
int prefixKeep = (Integer) args[0]; int prefixKeep = (Integer) args[0];
int suffixKeep = (Integer) args[1]; int suffixKeep = (Integer) args[1];
String replacer = (String) args[2]; String replacer = (String) args[2];
int length = origin.length(); int length = origin.length();
// 原始字符串长度小于等于保留长度,则原始字符串全部替换 // 情况一:原始字符串长度小于等于保留长度,则原始字符串全部替换
if (prefixKeep >= length || suffixKeep >= length) { if (prefixKeep >= length || suffixKeep >= length) {
return buildReplacerByLength(replacer, length); return buildReplacerByLength(replacer, length);
} }
// 如果原始字符串小于等于前后缀保留字符串长度,则原始字符串全部替换 // 情况二:如果原始字符串小于等于前后缀保留字符串长度,则原始字符串全部替换
if ((prefixKeep + suffixKeep) >= length) { if ((prefixKeep + suffixKeep) >= length) {
return buildReplacerByLength(replacer, length); return buildReplacerByLength(replacer, length);
} }
// 情况三TODO 城
int interval = length - prefixKeep - suffixKeep; int interval = length - prefixKeep - suffixKeep;
return origin.substring(0, prefixKeep) + return origin.substring(0, prefixKeep) +
buildReplacerByLength(replacer, interval) + buildReplacerByLength(replacer, interval) +
origin.substring(prefixKeep + interval); origin.substring(prefixKeep + interval);
} }
// TODO @城:类似,子类直接获取到参数哈
/** /**
* *
* *
@ -49,4 +50,5 @@ public abstract class AbstractDesensitizationHandler<T extends Annotation> imple
private String buildReplacerByLength(String replacer, int length) { private String buildReplacerByLength(String replacer, int length) {
return String.valueOf(replacer).repeat(Math.max(0, length)); return String.valueOf(replacer).repeat(Math.max(0, length));
} }
} }

View File

@ -19,16 +19,19 @@ import java.io.IOException;
import java.lang.annotation.Annotation; import java.lang.annotation.Annotation;
import java.lang.reflect.Field; import java.lang.reflect.Field;
// TODO @城:挪到 base/serializer 包下
/** /**
* *
*/ */
public class StringDesensitizeSerializer extends StdSerializer<String> implements ContextualSerializer { public class StringDesensitizeSerializer extends StdSerializer<String> implements ContextualSerializer {
private DesensitizationHandler desensitizationHandler; private DesensitizationHandler desensitizationHandler;
protected StringDesensitizeSerializer() { protected StringDesensitizeSerializer() {
super(String.class); super(String.class);
} }
// TODO @城get 和 set 方法是必须的么?如果是的话,可以换成 lombok 注解哈,简洁一点~
public DesensitizationHandler getDesensitizationHandler() { public DesensitizationHandler getDesensitizationHandler() {
return desensitizationHandler; return desensitizationHandler;
} }
@ -55,6 +58,7 @@ public class StringDesensitizeSerializer extends StdSerializer<String> implement
return; return;
} }
// TODO @城:抽个 private getField 方法。让这个方法的逻辑主干,更清晰
String currentName = gen.getOutputContext().getCurrentName(); String currentName = gen.getOutputContext().getCurrentName();
Object currentValue = gen.getCurrentValue(); Object currentValue = gen.getCurrentValue();
Class<?> currentValueClass = currentValue.getClass(); Class<?> currentValueClass = currentValue.getClass();
@ -66,16 +70,13 @@ public class StringDesensitizeSerializer extends StdSerializer<String> implement
gen.writeString(value); gen.writeString(value);
return; return;
} }
for (Annotation annotation : field.getAnnotations()) { for (Annotation annotation : field.getAnnotations()) {
if (AnnotationUtil.hasAnnotation(annotation.annotationType(), Desensitize.class)) { if (AnnotationUtil.hasAnnotation(annotation.annotationType(), Desensitize.class)) {
value = this.desensitizationHandler.desensitize(value, annotation); value = this.desensitizationHandler.desensitize(value, annotation);
gen.writeString(value); gen.writeString(value);
return; return;
} }
} }
gen.writeString(value); gen.writeString(value);
} }