要求对接口中含有的电话、身份证、名字进行脱敏处理显示部分数据,并对老的接口同步改造,由于改动部分较多。想到了利用自定义注解配合切面处理,减少对原本接口的改动。
注意:注解及切面只针对String类型的属性有效
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface Desensitize {
DesensitizeStrategy value() ;
}
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.*;
import org.springframework.stereotype.Component;
import java.lang.reflect.Field;
import java.util.Objects;
@Aspect
@Component
public class DesensitizeAspect {
@Pointcut("execution(* com.demo.controller..*(..))")
public void desensitize() {
}
@Around("desensitize()")
public Object doDesensitize(ProceedingJoinPoint joinPoint) throws Throwable {
Object result = joinPoint.proceed();
if (result != null) {
Field[] fields = result.getClass().getDeclaredFields();
for (Field field : fields) {
if (field.isAnnotationPresent(Desensitize.class)) {
field.setAccessible(true);
Object value = field.get(result);
//判断只有字段为字符串同时具有Desensitize注解才生效
if (value instanceof String) {
Desensitize annotation = field.getAnnotation(Desensitize.class);
DesensitizeStrategy strategy = annotation.value();
if (Objects.nonNull(strategy)) {
field.set(result, strategy.desensitizer().apply(value.toString()));
}
}
}
}
}
return result;
}
}
import java.util.function.Function;
/**
* 脱敏策略,枚举类,针对不同的数据定制特定的策略
*/
public enum DesensitizeStrategy {
/**
* 用户名
*/
USERNAME(s -> s.replaceAll("(\\S)\\S(\\S*)", "$1*$2")),
/**
* 身份证
*/
ID_CARD(s -> s.replaceAll("(\\d{4})\\d{10}(\\w{4})", "$1****$2")),
/**
* 手机号
*/
PHONE(s -> s.replaceAll("(\\d{3})\\d{4}(\\d{4})", "$1****$2")),
/**
* 地址
*/
ADDRESS(s -> s.replaceAll("(\\S{3})\\S{2}(\\S*)\\S{2}", "$1****$2****"));
private final Function<String, String> desensitizer;
DesensitizeStrategy(Function<String, String> desensitizer) {
this.desensitizer = desensitizer;
}
public Function<String, String> desensitizer() {
return desensitizer;
}
}
因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- ovod.cn 版权所有 湘ICP备2023023988号-4
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务