Spring boot 基于注解 正則數(shù)據(jù)脫敏

1.首先創(chuàng)建注解類

import com.fasterxml.jackson.annotation.JacksonAnnotationsInside;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.jian.common.desen.BaseRule;
import com.jian.common.desen.DefaultRule;
import com.jian.common.desen.MyJsonSerializer;

import java.lang.annotation.*;

/**
 * @author Administrator
 */
@JacksonAnnotationsInside
@JsonSerialize(using = MyJsonSerializer.class)
@Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
public @interface CustomSerializer {

    /**
     * 脫敏規(guī)則處理類
     * @return
     */
    Class<? extends BaseRule> value() default DefaultRule.class;

    /**
     * 正則,pattern和format必需同時有值。如果都有值時,優(yōu)先使用正則進行規(guī)則替換
     * @return
     */
    String pattern() default "";

    String format() default "";

}

2.創(chuàng)建注解檢查 轉(zhuǎn)換類


import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.databind.BeanProperty;
import com.fasterxml.jackson.databind.JsonMappingException;
import com.fasterxml.jackson.databind.JsonSerializer;
import com.fasterxml.jackson.databind.SerializerProvider;
import com.fasterxml.jackson.databind.ser.ContextualSerializer;
import com.jian.common.annotation.CustomSerializer;
import lombok.extern.slf4j.Slf4j;

import java.io.IOException;

@Slf4j
public class MyJsonSerializer extends JsonSerializer<String> implements ContextualSerializer {

    /**
     * 脫敏規(guī)則
     */
    private BaseRule rule;

    @Override
    public void serialize(String value, JsonGenerator gen, SerializerProvider serializers) throws IOException {
        gen.writeString(rule.apply(value));
    }

    @Override
    public JsonSerializer<?> createContextual(SerializerProvider prov, BeanProperty property) throws JsonMappingException {
        //獲取對象屬性上的自定義注解
        CustomSerializer customSerializer = property.getAnnotation(CustomSerializer.class);
        if (null != customSerializer) {
            try {
                //根據(jù)注解的配置信息,創(chuàng)建對應脫敏規(guī)則處理類
                this.rule = customSerializer.value().newInstance();
                //如果正則信息不為空,則使用注解上的正則初始化到對應的脫敏規(guī)則處理類中
                if (isNotBlank(customSerializer.pattern()) && isNotBlank(customSerializer.format())) {
                    this.rule.setRule(new RuleItem()
                            .setRegex(customSerializer.pattern())
                            .setFormat(customSerializer.format()));
                }
                return this;
            } catch (Exception e) {
                log.error("json轉(zhuǎn)換處理異常", e);
            }
        }
        return prov.findValueSerializer(property.getType(), property);
    }

    private boolean isNotBlank(String str) {
        return null != str && str.trim().length() > 0;
    }
}

3.創(chuàng)建數(shù)據(jù)脫敏基類

package com.jian.common.desen;

import lombok.Data;

import java.util.function.Function;
//脫敏處理基類
@Data
public abstract class BaseRule implements Function<String, String> {
    /**
     * 脫敏規(guī)則對象
     */
    private RuleItem rule;

    @Override
    public String apply(String str) {
        if (null == str) {
            return null;
        }
        //初始化脫敏規(guī)則
        initRule();
        if (null == rule || null == rule.getRegex() || null == rule.getFormat()) {
            return str;
        }
        //正則替換
        return str.replaceAll(rule.getRegex(), rule.getFormat());
    }
    abstract void initRule();
}

4.注解參數(shù)以及默認處理類


import lombok.Data;
import lombok.experimental.Accessors;

@Data
@Accessors(chain = true)
public class RuleItem {

    /**
     * 正則
     */
    private String regex;

    /**
     * 格式化顯示
     */
    private String format;
}

public class DefaultRule extends BaseRule {
    @Override
    void initRule() {

    }
}

5.實現(xiàn)基類,自定義處理脫敏規(guī)則

例如手機號脫敏


//手機號脫敏處理類
public class PhoneRule extends BaseRule {

    /**
     * 僅顯示前3位和后4位
     */
    @Override
    void initRule() {
        setRule(new RuleItem()
                .setRegex("(\\d{3})\\d*(\\d{4})")
                .setFormat("$1****$2"));
    }

}

身份證號碼脫敏

//身份證號脫敏處理類
public class IdCardRule extends BaseRule {

    /**
     * 僅顯示前6位和后4位
     */
    @Override
    void initRule() {
        setRule(new RuleItem()
                .setRegex("(\\d{6})\\d*(\\w{4})")
                .setFormat("$1********$2"));
    }

}

用戶名脫敏

//姓名脫敏處理類
public class UserNameRule extends BaseRule {

    /**
     * 僅顯示最后一個漢字
     */
    @Override
    void initRule() {
        setRule(new RuleItem()
                .setRegex("\\S*(\\S)")
                .setFormat("**$1"));
    }
}

6.實體類屬性上面加上注解

 @CustomSerializer(value = PhoneRule.class)
 private String phonenumber;

這樣子返回的數(shù)據(jù),就會脫敏返回啦

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容