WechatGroup
This commit is contained in:
		| @@ -0,0 +1,122 @@ | ||||
| package com.ruoyi.common.config; | ||||
|  | ||||
| import org.springframework.boot.context.properties.ConfigurationProperties; | ||||
| import org.springframework.stereotype.Component; | ||||
|  | ||||
| /** | ||||
|  * 读取项目相关配置 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Component | ||||
| @ConfigurationProperties(prefix = "ruoyi") | ||||
| public class RuoYiConfig | ||||
| { | ||||
|     /** 项目名称 */ | ||||
|     private String name; | ||||
|  | ||||
|     /** 版本 */ | ||||
|     private String version; | ||||
|  | ||||
|     /** 版权年份 */ | ||||
|     private String copyrightYear; | ||||
|  | ||||
|     /** 上传路径 */ | ||||
|     private static String profile; | ||||
|  | ||||
|     /** 获取地址开关 */ | ||||
|     private static boolean addressEnabled; | ||||
|  | ||||
|     /** 验证码类型 */ | ||||
|     private static String captchaType; | ||||
|  | ||||
|     public String getName() | ||||
|     { | ||||
|         return name; | ||||
|     } | ||||
|  | ||||
|     public void setName(String name) | ||||
|     { | ||||
|         this.name = name; | ||||
|     } | ||||
|  | ||||
|     public String getVersion() | ||||
|     { | ||||
|         return version; | ||||
|     } | ||||
|  | ||||
|     public void setVersion(String version) | ||||
|     { | ||||
|         this.version = version; | ||||
|     } | ||||
|  | ||||
|     public String getCopyrightYear() | ||||
|     { | ||||
|         return copyrightYear; | ||||
|     } | ||||
|  | ||||
|     public void setCopyrightYear(String copyrightYear) | ||||
|     { | ||||
|         this.copyrightYear = copyrightYear; | ||||
|     } | ||||
|  | ||||
|     public static String getProfile() | ||||
|     { | ||||
|         return profile; | ||||
|     } | ||||
|  | ||||
|     public void setProfile(String profile) | ||||
|     { | ||||
|         RuoYiConfig.profile = profile; | ||||
|     } | ||||
|  | ||||
|     public static boolean isAddressEnabled() | ||||
|     { | ||||
|         return addressEnabled; | ||||
|     } | ||||
|  | ||||
|     public void setAddressEnabled(boolean addressEnabled) | ||||
|     { | ||||
|         RuoYiConfig.addressEnabled = addressEnabled; | ||||
|     } | ||||
|  | ||||
|     public static String getCaptchaType() { | ||||
|         return captchaType; | ||||
|     } | ||||
|  | ||||
|     public void setCaptchaType(String captchaType) { | ||||
|         RuoYiConfig.captchaType = captchaType; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取导入上传路径 | ||||
|      */ | ||||
|     public static String getImportPath() | ||||
|     { | ||||
|         return getProfile() + "/import"; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取头像上传路径 | ||||
|      */ | ||||
|     public static String getAvatarPath() | ||||
|     { | ||||
|         return getProfile() + "/avatar"; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取下载路径 | ||||
|      */ | ||||
|     public static String getDownloadPath() | ||||
|     { | ||||
|         return getProfile() + "/download/"; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取上传路径 | ||||
|      */ | ||||
|     public static String getUploadPath() | ||||
|     { | ||||
|         return getProfile() + "/upload"; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,67 @@ | ||||
| package com.ruoyi.common.config.serializer; | ||||
|  | ||||
| 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.annotation.Sensitive; | ||||
| import com.ruoyi.common.core.domain.model.LoginUser; | ||||
| import com.ruoyi.common.enums.DesensitizedType; | ||||
| import com.ruoyi.common.utils.SecurityUtils; | ||||
|  | ||||
| /** | ||||
|  * 数据脱敏序列化过滤 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class SensitiveJsonSerializer extends JsonSerializer<String> implements ContextualSerializer | ||||
| { | ||||
|     private DesensitizedType desensitizedType; | ||||
|  | ||||
|     @Override | ||||
|     public void serialize(String value, JsonGenerator gen, SerializerProvider serializers) throws IOException | ||||
|     { | ||||
|         if (desensitization()) | ||||
|         { | ||||
|             gen.writeString(desensitizedType.desensitizer().apply(value)); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             gen.writeString(value); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public JsonSerializer<?> createContextual(SerializerProvider prov, BeanProperty property) | ||||
|             throws JsonMappingException | ||||
|     { | ||||
|         Sensitive annotation = property.getAnnotation(Sensitive.class); | ||||
|         if (Objects.nonNull(annotation) && Objects.equals(String.class, property.getType().getRawClass())) | ||||
|         { | ||||
|             this.desensitizedType = annotation.desensitizedType(); | ||||
|             return this; | ||||
|         } | ||||
|         return prov.findValueSerializer(property.getType(), property); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 是否需要脱敏处理 | ||||
|      */ | ||||
|     private boolean desensitization() | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             LoginUser securityUser = SecurityUtils.getLoginUser(); | ||||
|             // 管理员不脱敏 | ||||
|             return !securityUser.getUser().isAdmin(); | ||||
|         } | ||||
|         catch (Exception e) | ||||
|         { | ||||
|             return true; | ||||
|         } | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user