• Swagger展示枚举类型参数


    实现原理:修改@ApiModelProperty的属性:value、dataType、allowableValues

    @Component
    public class SwaggerDisplayConfig implements ModelPropertyBuilderPlugin {
        @Override
        public void apply(ModelPropertyContext context) {
            AnnotatedField field = context.getBeanPropertyDefinition().get().getField();
            Class<?> rawType = field.getRawType();
            if (!rawType.isEnum()) {
                return;
            }
            ApiModelProperty annotation = field.getAnnotation(ApiModelProperty.class);
            // Annotation是通过代理来设置并存储属性值的
            InvocationHandler ih = Proxy.getInvocationHandler(annotation);
            try {
                // Annotation所有属性的值都存储在InvocationHandler的memberValues属性,该属性类型为Map
                Field memberValuesField = ih.getClass().getDeclaredField("memberValues");
                memberValuesField.setAccessible(true);
                Map memberValues = (Map)memberValuesField.get(ih);
                String className = rawType.getDeclaredField("value").getType().getName();
                memberValues.put("dataType", className);
                Object[] enumConstants = rawType.getEnumConstants();
                Method getValue = rawType.getMethod("getValue");
                Method getDesc = rawType.getMethod("getDesc");
                List<String> descriptions = new ArrayList<>();
                List<String> allowableValues = new ArrayList<>();
                for (Object e : enumConstants){
                    String v = getValue.invoke(e).toString();
                    allowableValues.add(v);
                    descriptions.add(v + ":" + getDesc.invoke(e));
                }
                memberValues.put("value", ((String)memberValues.get("value")).concat("。").concat(String.join(",", descriptions)));
                memberValues.put("allowableValues", String.join(",", allowableValues));
            } catch (NoSuchFieldException | IllegalAccessException | NoSuchMethodException | InvocationTargetException e) {
                e.printStackTrace();
            }
        }
    
        @Override
        public boolean supports(DocumentationType documentationType) {
            return true;
        }
    }

    效果

  • 相关阅读:
    ADO.NET改进版
    H面试程序(11): 判断字符串是否包含子串问题
    H面试程序(12): 输出字符串中第一个只出现一次的字母
    Hadoop CLI MiniCluster
    hdu 3061 (最大权闭合图)
    CF 338 D GCD Table(CRT)
    【Todo】Nodejs学习计划
    【转载】游戏并发编程的讨论 & Nodejs并发性讨论 & 语法糖术语
    Jedis(Java+Redis) Pool的使用
    【Todo】Apache-Commons-Pool及对象池学习
  • 原文地址:https://www.cnblogs.com/joequa/p/14113805.html
Copyright © 2020-2023  润新知