当前位置: 首页 > news >正文

番禺电子商务网站建设百度投诉中心入口

番禺电子商务网站建设,百度投诉中心入口,做网站用什么域名好,公司注册地址变更需要哪些资料本期内容 添加SpringDoc配置展示枚举字段#xff0c;在文档页面中显示枚举值和对应的描述添加SpringMVC配置使项目可以接收枚举值#xff0c;根据枚举值找到对应的枚举 默认内容 先不做任何处理看一下直接使用枚举当做入参是什么效果。 定义一个枚举 package com.exampl…本期内容 添加SpringDoc配置展示枚举字段在文档页面中显示枚举值和对应的描述添加SpringMVC配置使项目可以接收枚举值根据枚举值找到对应的枚举 默认内容 先不做任何处理看一下直接使用枚举当做入参是什么效果。 定义一个枚举 package com.example.enums;import lombok.AllArgsConstructor; import lombok.Getter;/*** 来源枚举** author vains*/ Getter AllArgsConstructor public enum SourceEnum {/*** 1-web网站*/WEB(1, web网站),/*** 2-APP应用*/APP(2, APP应用);/*** 来源代码*/private final Integer value;/*** 来源名称*/private final String source;} 定义一个入参类 package com.example.model;import com.example.enums.SourceEnum; import io.swagger.v3.oas.annotations.media.Schema; import lombok.Data;/*** 枚举属性类** author vains*/ Data Schema(title 包含枚举属性的类) public class EnumModel {Schema(title 名字)private String name;Schema(title 来源)private SourceEnum source;} 定义一个接口测试枚举入参的效果 package com.example.controller;import com.example.enums.SourceEnum; import com.example.model.EnumModel; import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.tags.Tag; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;/*** 枚举接口** author vains*/ RestController RequestMapping(/enum) Tag(name 枚举入参接口, description 提供以枚举作为入参的接口展示SpringDoc自定义配置效果) public class EnumController {GetMapping(/test01/{source})Operation(summary url参数枚举, description 将枚举当做url参数)public SourceEnum test01(PathVariable SourceEnum source) {return source;}GetMapping(/test02)Operation(summary 查询参数枚举, description 将枚举当做查询参数)public SourceEnum test02(SourceEnum source) {return source;}PostMapping(value /test03)Operation(summary 参数类包含枚举, description 将枚举当做参数类的属性)public EnumModel test03(RequestBody EnumModel model) {return model;}} 启动项目查看接口文档显示效果 单个枚举效果 作为参数属性显示效果 文档中默认显示枚举可接收的值是定义的枚举名字(APP,WEB)但是在实际开发中前端会传入枚举对应的值/代码(1,2)根据代码映射到对应的枚举。 解决方案 单个处理方案 枚举入参 详细内容见文档 使用Parameter注解(方法上/参数前)或者Parameters注解来指定枚举参数可接受的值。如下所示 例1 GetMapping(/test01/{source}) Parameter(name source, schema Schema(description 来源枚举, type int32, allowableValues {1, 2})) Operation(summary url参数枚举, description 将枚举当做url参数) public SourceEnum test01(PathVariable SourceEnum source) {return source; }例2 GetMapping(/test01/{source}) Operation(summary url参数枚举, description 将枚举当做url参数) public SourceEnum test01(PathVariableParameter(name source, schema Schema(description 来源枚举, type int32, allowableValues {1, 2}))SourceEnum source) {return source; }单独枚举入参显示效果 枚举作为参数类属性 单独处理没有好的办法像上边添加allowableValues属性只会在原有列表上添加如下 全局统一处理方案 准备工作 定义一个统一枚举接口 package com.example.enums;import com.fasterxml.jackson.annotation.JsonValue;import java.io.Serializable; import java.util.Arrays; import java.util.Objects;/*** 通用枚举接口** param V 枚举值的类型* param E 子枚举类型* author vains*/ public interface BasicEnumV extends Serializable, E extends EnumE {JsonValueV getValue();/*** 根据子枚举和子枚举对应的入参值找到对应的枚举类型** param value 子枚举中对应的值* param clazz 子枚举类型* param B {link BasicEnum} 的子类类型* param V 子枚举值的类型* param E 子枚举的类型* return 返回 {link BasicEnum} 对应的子类实例*/static B extends BasicEnumV, E, V extends Serializable, E extends EnumE B fromValue(V value, ClassB clazz) {return Arrays.stream(clazz.getEnumConstants()).filter(e - Objects.equals(e.getValue(), value)).findFirst().orElse(null);}} 我这里为了通用性将枚举值的类型也设置为泛型类型了如果不需要可以设置为具体的类型比如String、Integer等如果像我这样处理起来会稍微麻烦一些另外我这里只提供了一个getValue的抽象方法你也可以再提供一个getName、getDescription等获取枚举描述字段值的抽象方法。 让项目中的枚举实现BasicEnum接口并重写getValue方法如下 package com.example.enums;import lombok.AllArgsConstructor; import lombok.Getter;/*** 来源枚举** author vains*/ Getter AllArgsConstructor public enum SourceEnum implements BasicEnumInteger, SourceEnum {/*** 1-web网站*/WEB(1, web网站),/*** 2-APP应用*/APP(2, APP应用);/*** 来源代码*/private final Integer value;/*** 来源名称*/private final String source;} 定义一个基础自定义接口,提供一些对枚举的操作方法 package com.example.config.basic;import io.swagger.v3.core.util.PrimitiveType; import io.swagger.v3.oas.models.media.ObjectSchema; import io.swagger.v3.oas.models.media.Schema; import org.springframework.beans.BeanUtils; import org.springframework.util.ReflectionUtils;import java.lang.reflect.Field; import java.lang.reflect.Method; import java.lang.reflect.Modifier; import java.lang.reflect.Type; import java.util.Arrays; import java.util.Comparator; import java.util.List; import java.util.Objects; import java.util.stream.Collectors;/*** 基础自定义接口** author vains*/ public interface BasicEnumCustomizer {/*** 获取枚举的所有值** param enumClazz 枚举的class* return 枚举的所有值*/default ListObject getValues(Class? enumClazz) {return Arrays.stream(enumClazz.getEnumConstants()).filter(Objects::nonNull).map(item - {// 收集valuesMethod getValue ReflectionUtils.findMethod(item.getClass(), getValue);if (getValue ! null) {ReflectionUtils.makeAccessible(getValue);return ReflectionUtils.invokeMethod(getValue, item);}return null;}).filter(Objects::nonNull).toList();}/*** 获取值和描述对应的描述信息值和描述信息以“:”隔开** param enumClazz 枚举class* return 描述信息*/default String getDescription(Class? enumClazz) {ListField fieldList Arrays.stream(enumClazz.getDeclaredFields()).filter(f - !Modifier.isStatic(f.getModifiers()))// 排序.sorted(Comparator.comparing(Field::getName).reversed()).toList();fieldList.forEach(ReflectionUtils::makeAccessible);return Arrays.stream(enumClazz.getEnumConstants()).filter(Objects::nonNull).map(item - fieldList.stream().map(field - ReflectionUtils.getField(field, item)).map(String::valueOf).collect(Collectors.joining( : ))).collect(Collectors.joining( ));}/*** 根据枚举值的类型获取对应的 {link Schema} 类* 这么做是因为当SpringDoc获取不到属性的具体类型时会自动生成一个string类型的 {link Schema} * 所以需要根据枚举值的类型获取不同的实例例如 {link io.swagger.v3.oas.models.media.IntegerSchema}、* {link io.swagger.v3.oas.models.media.StringSchema}** param type 枚举值的类型* param sourceSchema 从属性中加载的 {link Schema} 类* return 获取枚举值类型对应的 {link Schema} 类*/SuppressWarnings({unchecked})default SchemaObject getSchemaByType(Type type, Schema? sourceSchema) {SchemaObject schema;PrimitiveType item PrimitiveType.fromType(type);if (item null) {schema new ObjectSchema();} else {schema item.createProperty();}// 获取schema的type和formatString schemaType schema.getType();String format schema.getFormat();// 复制原schema的其它属性BeanUtils.copyProperties(sourceSchema, schema);// 使用根据枚举值类型获取到的schemareturn schema.type(schemaType).format(format);}} 全局自定义内容都是基于org.springdoc.core.customizers包下的一些Customizer接口SpringDoc在扫描接口信息时会调用这些接口以实现加载使用者的自定义内容所以这里提供一个基础的Customizer接口。 实现枚举参数自定义 定义一个ApiEnumParameterCustomizer类并实现ParameterCustomizer接口实现对枚举入参的自定义同时实现BasicEnumCustomizer接口使用工具方法。 package com.example.config.customizer;import com.example.config.basic.BasicEnumCustomizer; import com.example.enums.BasicEnum; import io.swagger.v3.oas.models.media.Schema; import io.swagger.v3.oas.models.parameters.Parameter; import org.springdoc.core.customizers.ParameterCustomizer; import org.springframework.core.MethodParameter; import org.springframework.stereotype.Component;/*** 枚举参数自定义配置** author vains*/ Component public class ApiEnumParameterCustomizer implements ParameterCustomizer, BasicEnumCustomizer {Overridepublic Parameter customize(Parameter parameterModel, MethodParameter methodParameter) {Class? parameterType methodParameter.getParameterType();// 枚举处理if (BasicEnum.class.isAssignableFrom(parameterType)) {parameterModel.setDescription(getDescription(parameterType));SchemaObject schema new Schema();schema.setEnum(getValues(parameterType));parameterModel.setSchema(schema);}return parameterModel;} } 实现枚举属性的自定义 定义一个ApiEnumPropertyCustomizer类并实现PropertyCustomizer接口实现对枚举属性的自定义同时实现BasicEnumCustomizer接口使用工具方法。 package com.example.config.customizer;import com.example.config.basic.BasicEnumCustomizer; import com.example.enums.BasicEnum; import com.fasterxml.jackson.databind.type.SimpleType; import io.swagger.v3.core.converter.AnnotatedType; import io.swagger.v3.oas.models.media.Schema; import org.springdoc.core.customizers.PropertyCustomizer; import org.springframework.stereotype.Component; import org.springframework.util.ObjectUtils;import java.lang.reflect.ParameterizedType; import java.lang.reflect.Type;/*** 枚举属性自定义配置** author vains*/ Component public class ApiEnumPropertyCustomizer implements PropertyCustomizer, BasicEnumCustomizer {Overridepublic Schema? customize(Schema property, AnnotatedType type) {// 检查实例并转换if (type.getType() instanceof SimpleType fieldType) {// 获取字段classClass? fieldClazz fieldType.getRawClass();// 是否是枚举if (BasicEnum.class.isAssignableFrom(fieldClazz)) {// 获取父接口if (fieldClazz.getGenericInterfaces()[0] instanceof ParameterizedType parameterizedType) {// 通过父接口获取泛型中枚举值的class类型Type actualTypeArgument parameterizedType.getActualTypeArguments()[0];SchemaObject schema getSchemaByType(actualTypeArgument, property);// 重新设置字段的注释和默认值schema.setEnum(this.getValues(fieldClazz));// 获取字段注释String description this.getDescription(fieldClazz);// 重置字段注释和标题为从枚举中提取的if (ObjectUtils.isEmpty(property.getTitle())) {schema.setTitle(description);} else {schema.setTitle(property.getTitle() ( description ));}if (ObjectUtils.isEmpty(property.getDescription())) {schema.setDescription(description);} else {schema.setDescription(property.getDescription() ( description ));}return schema;}}}return property;}} 如果读者不喜欢这样的效果可以自行修改枚举值、描述信息的显示效果 重启项目查看效果 接口1 接口2 接口3 SpringBoot接收枚举入参处理 不知道大家有没有注意到BasicEnum接口中的抽象方法getValue上有一个JsonValue注解这个注解会在进行Json序列化时会将该方法返回的值当做当前枚举的值例如1/2如果不加该注解则序列化时会直接变为枚举的名字例如: APP/WEB。 如果Restful接口入参中有RequestBody注解则在——统一枚举的getValue方法上有JsonValue注解的基础上无需做任何处理对于Json入参可以这样处理但是对于POST表单参数或GET查询参数需要添加单独的处理。 定义一个EnumConverterFactory 根据枚举的class类型获取对应的converter并在converter中直接将枚举值转为对应的枚举 具体逻辑情况代码中的注释 package com.example.config.converter;import com.example.enums.BasicEnum; import com.fasterxml.jackson.databind.type.TypeFactory; import lombok.NonNull; import org.springframework.core.convert.converter.Converter; import org.springframework.core.convert.converter.ConverterFactory; import org.springframework.stereotype.Component; import org.springframework.util.ReflectionUtils;import java.io.Serializable; import java.lang.reflect.Method; import java.lang.reflect.ParameterizedType; import java.lang.reflect.Type; import java.util.function.Function;/*** 处理除 {link org.springframework.web.bind.annotation.RequestBody } 注解标注之外是枚举的入参** param V 枚举值的类型* param E 枚举的类型* author vains*/ Component public class EnumConverterFactoryV extends Serializable, E extends EnumE implements ConverterFactoryString, BasicEnumV, E {NonNullOverrideSuppressWarnings(unchecked)public T extends BasicEnumV, E ConverterString, T getConverter(ClassT targetType) {// 获取父接口Type baseInterface targetType.getGenericInterfaces()[0];if (baseInterface instanceof ParameterizedType parameterizedType parameterizedType.getActualTypeArguments().length 2) {// 获取具体的枚举类型Type targetActualTypeArgument parameterizedType.getActualTypeArguments()[1];Class? targetAawArgument TypeFactory.defaultInstance().constructType(targetActualTypeArgument).getRawClass();// 判断是否实现自通用枚举if (BasicEnum.class.isAssignableFrom(targetAawArgument)) {// 获取父接口的泛型类型Type valueArgument parameterizedType.getActualTypeArguments()[0];// 获取值的classClassV valueRaw (ClassV) TypeFactory.defaultInstance().constructType(valueArgument).getRawClass();String valueOfMethod valueOf;// 转换入参的类型Method valueOf ReflectionUtils.findMethod(valueRaw, valueOfMethod, String.class);if (valueOf ! null) {ReflectionUtils.makeAccessible(valueOf);}// 将String类型的值转为枚举值对应的类型FunctionString, V castValue // 获取不到转换方法时直接返回nullsource - {if (valueRaw.isInstance(source)) {// String类型直接强转return valueRaw.cast(source);}// 其它包装类型使用valueOf转换return valueOf null ? null: (V) ReflectionUtils.invokeMethod(valueOf, valueRaw, source);};return source - BasicEnum.fromValue(castValue.apply(source), targetType);}}return source - null;}}定义一个WebmvcConfig配置类将EnumConverterFactory注册到添加到mvc配置中 package com.example.config;import com.example.config.converter.EnumConverterFactory; import lombok.AllArgsConstructor; import org.springframework.context.annotation.Configuration; import org.springframework.format.FormatterRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;/*** 添加自定义枚举转换配置** author vains*/ AllArgsConstructor Configuration(proxyBeanMethods false) public class WebmvcConfig implements WebMvcConfigurer {private final EnumConverterFactory?, ? enumConverterFactory;Overridepublic void addFormatters(FormatterRegistry registry) {registry.addConverterFactory(enumConverterFactory);} }重启项目并打开在线文档进行测试 Gitee地址、Github地址
http://www.sadfv.cn/news/290581/

相关文章:

  • 重庆旅游网站制作公司深圳十大建筑设计院
  • 一个简单的网站怎么做网络推广合同范本
  • 做网站都有什么项目东莞短视频的推广方法
  • h5做的分销网站个人店铺logo
  • 做网站如何找广告商wordpress 语言包修改
  • 建设银行网站地址wordpress relevanssi
  • 做网站需要用到哪些开发软件网站建设培训招生
  • 机械行业网站有哪些微信公司
  • wordpress vantage主题宿迁seo公司
  • 如何做自己的淘客网站淮安app开发
  • 9.9网站怎么做wordpress主题工作室
  • 比较好的 网站统计系统 php源码建网站的8个详细步骤
  • 北京网站定制公司如何提高 网站的点击量
  • 广告公司做网站的效果怎么样阿里巴巴网站建设过程
  • 广东省中山市网站哪有做建筑设计的网站
  • 网站 公司秦皇岛网站推广排名
  • 淘宝网站建设没法上传怎么办浙江省一建建设集团网站
  • 建设公司门户网站html购物网站怎么做
  • 网站建设学习网站最新国际军事新闻头条新闻
  • 群晖 建站 Wordpress绵阳网站开发公司
  • 湖州交通网站集约化建设项目苏州建网站的公司哪家口碑好
  • 镇江网站建设zjmfkj外贸网站假设
  • 公司两学一做网站网站建设模板可用吗
  • 青岛网站建设效果门户网站内容建设岗位职责
  • 网站开发技术入股协议手机怎么做微电影网站
  • 宝安建网站软件开发合同范本免费下载
  • 郑州做网站推广资讯做擦边球网站会不会违法呢
  • 龙岗高端网站建设公司logo图片
  • 西安建站广东网站建设公司电话
  • 淮安企业网站制作济南工程网站建设