您好,欢迎来到欧得旅游网。
搜索
您的当前位置:首页利用AOP数据脱敏

利用AOP数据脱敏

来源:欧得旅游网

背景

要求对接口中含有的电话、身份证、名字进行脱敏处理显示部分数据,并对老的接口同步改造,由于改动部分较多。想到了利用自定义注解配合切面处理,减少对原本接口的改动。

注意:注解及切面只针对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

本站由北京市万商天勤律师事务所王兴未律师提供法律服务