springboot实现枚举参数

springboot实现枚举参数

基础的枚举接口

java 复制代码
public interface BaseEnum<K, V> {
    /**
     * 获取值
     *
     * @return {@link K}
     */
    @JsonValue
    K getValue();

    /**
     * 获取描述
     *
     * @return {@link V}
     */
    V getDescription();

    @JsonCreator
    BaseEnum<K, V> find(K value);
}

枚举工具类

java 复制代码
public class BaseEnumUtil {

    /**
     * 代码
     *
     * @param enumClass 枚举类
     * @param code      密码
     * @return {@link E}
     */
    public static <E extends BaseEnum<Object, Object>> E codeOf(Class<E> enumClass, Object code) {
        E[] enumConstants = enumClass.getEnumConstants();
        for (E e : enumConstants) {
            if (e.getValue().toString().equals(code.toString())) {
                return e;
            }
        }
        return null;
    }

    public static <E extends BaseEnum> E codeOf(E[] values, Object code) {
        for (E e : values) {
            if (e.getValue().equals(code)) {
                return e;
            }
        }
        return null;
    }
}

1. json(以jackson为例)

BaseEnum接口中@JsonValue@JsonCreator是 Jackson JSON 处理库中的两个注解,它们用于在序列化反序列化过程中定制 Java 对象与 JSON 数据之间的映射。

示例枚举:

java 复制代码
@AllArgsConstructor
@Getter
public enum StatusEnum implements BaseEnum<Integer, String> {

    /**
     * 是
     */
    YES(1, "是"),
    /**
     * 否
     */
    NO(0, "否"),
    ;

    private final Integer value;
    private final String description;


    @Override
    public String toString() {
        return value.toString();
    }

    @Override
    public BaseEnum<Integer, String> find(Integer value) {
        return BaseEnumUtil.codeOf(values(),value);
    }
}

2. 表单参数

通过实现org.springframework.core.convert.converter.Converter的方法

  • 转换类
java 复制代码
@RequiredArgsConstructor
public class EnumConverter<E extends BaseEnum<Object, Object>> implements Converter<String, E> {

    private final Class<E> enumType;

    /**
     * 转换
     *
     * @param s s
     * @return {@link E}
     */
    @Override
    public E convert(@NonNull String s) {
        return BaseEnumUtil.codeOf(this.enumType, s);
    }
}
  • 转换工厂
java 复制代码
@Component
@NoArgsConstructor
public class EnumConverterFactory implements ConverterFactory<String, BaseEnum<Object, Object>> {

    /**
     * 获取转换器
     *
     * @param targetType 目标类型
     * @return {@link Converter}<{@link String}, {@link T}>
     */
    @NonNull
    public <T extends BaseEnum<Object, Object>> Converter<String, T> getConverter(@NonNull Class<T> targetType) {
        return new EnumConverter<>(targetType);
    }
}
  • MVC配置
java 复制代码
@Configuration
@RequiredArgsConstructor
public class SpringMvcConfig implements WebMvcConfigurer {


    private final EnumConverterFactory enumConverterFactory;

    /**
     * 添加格式化程序
     *
     * @param registry 注册表
     */
    @Override
    public void addFormatters(FormatterRegistry registry) {
        registry.addConverterFactory(this.enumConverterFactory);
    }
}
相关推荐
MESSIR222 分钟前
Spring IOC(控制反转)中常用注解
java·spring
摇滚侠17 分钟前
Spring Boot 3零基础教程,Demo小结,笔记04
java·spring boot·笔记
华洛30 分钟前
公开一个AI产品的商业逻辑与设计方案——AI带来的涂色卡自由
前端·后端·产品
追逐时光者40 分钟前
C#/.NET/.NET Core技术前沿周刊 | 第 57 期(2025年10.1-10.12)
后端·.net
笨手笨脚の1 小时前
设计模式-迭代器模式
java·设计模式·迭代器模式·行为型设计模式
间彧1 小时前
Spring Bean生命周期中init-method详解与项目实战
后端
间彧2 小时前
InitializingBean详解与项目实战应用
后端
间彧2 小时前
@PostConstruct详解与项目实战应用
后端
spencer_tseng2 小时前
Eclipse 4.7 ADT (Android Development Tools For Eclipse)
android·java·eclipse
jiajixi2 小时前
Go 异步编程
开发语言·后端·golang