From 68aeb581cc899f1fa284e6e353e0eb67cb244005 Mon Sep 17 00:00:00 2001 From: RuoYi Date: Wed, 15 Apr 2026 13:13:26 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E8=84=B1=E6=95=8F=E4=B8=8D?= =?UTF-8?q?=E7=94=9F=E6=95=88=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ruoyi-common/ruoyi-common-core/pom.xml | 2 +- .../sensitive/annotation/Sensitive.java | 6 +-- .../config/SensitiveJsonSerializer.java | 42 ++++++++++++------- 3 files changed, 30 insertions(+), 20 deletions(-) diff --git a/ruoyi-common/ruoyi-common-core/pom.xml b/ruoyi-common/ruoyi-common-core/pom.xml index 9cf746ee..191127bd 100644 --- a/ruoyi-common/ruoyi-common-core/pom.xml +++ b/ruoyi-common/ruoyi-common-core/pom.xml @@ -73,7 +73,7 @@ - com.fasterxml.jackson.core + tools.jackson.core jackson-databind diff --git a/ruoyi-common/ruoyi-common-sensitive/src/main/java/com/ruoyi/common/sensitive/annotation/Sensitive.java b/ruoyi-common/ruoyi-common-sensitive/src/main/java/com/ruoyi/common/sensitive/annotation/Sensitive.java index 30b24b3d..538d7f1f 100644 --- a/ruoyi-common/ruoyi-common-sensitive/src/main/java/com/ruoyi/common/sensitive/annotation/Sensitive.java +++ b/ruoyi-common/ruoyi-common-sensitive/src/main/java/com/ruoyi/common/sensitive/annotation/Sensitive.java @@ -5,9 +5,9 @@ import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; import com.fasterxml.jackson.annotation.JacksonAnnotationsInside; -import com.fasterxml.jackson.databind.annotation.JsonSerialize; import com.ruoyi.common.sensitive.config.SensitiveJsonSerializer; import com.ruoyi.common.sensitive.enums.DesensitizedType; +import tools.jackson.databind.annotation.JsonSerialize; /** * 数据脱敏注解 @@ -15,10 +15,10 @@ import com.ruoyi.common.sensitive.enums.DesensitizedType; * @author ruoyi */ @Retention(RetentionPolicy.RUNTIME) -@Target(ElementType.FIELD) +@Target({ ElementType.FIELD, ElementType.METHOD }) @JacksonAnnotationsInside @JsonSerialize(using = SensitiveJsonSerializer.class) public @interface Sensitive { DesensitizedType desensitizedType(); -} +} \ No newline at end of file diff --git a/ruoyi-common/ruoyi-common-sensitive/src/main/java/com/ruoyi/common/sensitive/config/SensitiveJsonSerializer.java b/ruoyi-common/ruoyi-common-sensitive/src/main/java/com/ruoyi/common/sensitive/config/SensitiveJsonSerializer.java index cbb0d7eb..265f30ed 100644 --- a/ruoyi-common/ruoyi-common-sensitive/src/main/java/com/ruoyi/common/sensitive/config/SensitiveJsonSerializer.java +++ b/ruoyi-common/ruoyi-common-sensitive/src/main/java/com/ruoyi/common/sensitive/config/SensitiveJsonSerializer.java @@ -1,31 +1,43 @@ package com.ruoyi.common.sensitive.config; -import java.io.IOException; import java.util.Objects; -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.ruoyi.common.core.constant.UserConstants; import com.ruoyi.common.core.context.SecurityContextHolder; import com.ruoyi.common.sensitive.annotation.Sensitive; import com.ruoyi.common.sensitive.enums.DesensitizedType; +import tools.jackson.core.JacksonException; +import tools.jackson.core.JsonGenerator; +import tools.jackson.databind.BeanProperty; +import tools.jackson.databind.DatabindException; +import tools.jackson.databind.SerializationContext; +import tools.jackson.databind.ValueSerializer; +import tools.jackson.databind.ser.std.StdSerializer; /** * 数据脱敏序列化过滤 * * @author ruoyi */ -public class SensitiveJsonSerializer extends JsonSerializer implements ContextualSerializer +public class SensitiveJsonSerializer extends StdSerializer { - private DesensitizedType desensitizedType; + private final DesensitizedType desensitizedType; + + public SensitiveJsonSerializer() + { + super(String.class); + this.desensitizedType = null; + } + + public SensitiveJsonSerializer(DesensitizedType desensitizedType) + { + super(String.class); + this.desensitizedType = desensitizedType; + } @Override - public void serialize(String value, JsonGenerator gen, SerializerProvider serializers) throws IOException + public void serialize(String value, JsonGenerator gen, SerializationContext ctxt) throws JacksonException { - if (desensitization()) + if (desensitizedType != null && desensitization()) { gen.writeString(desensitizedType.desensitizer().apply(value)); } @@ -36,16 +48,14 @@ public class SensitiveJsonSerializer extends JsonSerializer implements C } @Override - public JsonSerializer createContextual(SerializerProvider prov, BeanProperty property) - throws JsonMappingException + public ValueSerializer createContextual(SerializationContext ctxt, BeanProperty property) throws DatabindException { Sensitive annotation = property.getAnnotation(Sensitive.class); if (Objects.nonNull(annotation) && Objects.equals(String.class, property.getType().getRawClass())) { - this.desensitizedType = annotation.desensitizedType(); - return this; + return new SensitiveJsonSerializer(annotation.desensitizedType()); } - return prov.findValueSerializer(property.getType(), property); + return ctxt.findValueSerializer(property.getType()); } /**