使用fastjosn作为消息转换器,与openapi冲突问题

简介: 从Swagger 2升级到SpringDoc过程中,初整合SpringSecurity时遭遇重重难关。首战主页访问受阻,调整安全配置终通行。次遇文档版本不明,困惑不已。最棘手乃JSON序列化问题,快被逼疯。导师相助锁定疑点,在日期处理上,Fastjson与SpringDoc不兼容。解决方案:或回归Jackson,或自定义Fastjson字符串序列化器。经历三日奋战,终告捷,感慨良多。

以前用的swagger2,忽然发现springdoc还在更新,就开始尝试新玩法,项目中加入了springsecutiry,第一次使用过程中还是遇到许多的bug,最终还有一个非常不理解的问题,经导师寻找最终找到问题所在,终解决,感动两年半,下面细谈:
首先遇到第一个bug,死活进不去主页http://localhost:8080/swagger-ui/index.html#/
这是swagger的文档,找着找着才忽然发现自己把自己拦截了,赶紧把自己放过去
.antMatchers(
HttpMethod.GET, // Swagger的资源路径需要允许访问
"/",
"/swagger-ui.html",
"/swagger-ui/",
"/.html",
"/favicon.ico",
"/swagger-resources/",
"/v3/api-docs/
"
// "/swagger-ui/index.html",
// "/swagger-ui.html",
// "/swagger-ui/*",
// "/v3/api-docs/
",
// "/v3/api-docs"
).permitAll()
终于进去了!!!当我以为我已经成功了,没想到:
Unable to render this definition
The provided definition does not specify a valid version field.

Please indicate a valid Swagger or OpenAPI version field. Supported version fields are swagger: "2.0" and those that match openapi: 3.0.n (for example, openapi: 3.0.0).
image.png

这个问题把我尬住了,以前也算是遇过,把各种问题排除,以及不断的尝试,死活过不去,真是一个bug找了两年半,看不太懂底层,没办法一个个排,只能硬找,通过三天三夜的努力,我成功放弃了,我找不到!!!!!
image.png

都有接收到,但是json序列化炸了,真是理解不能。
好不容易熬到周一,赶紧找我导师问一问,经过他一顿操作,帮我锁定了问题,说把一段代码注释掉就行,我当场蒙蔽了,一尝试就可以了!!--------无语
原来根本不是我配置的问题,因为在处理日期json序列化的时候,我们一般有三种方法:

  • @JSONField(format = "...")来指定格式
  • .setDateFormat("...")指定全局Date字段的序列化格式
  • setSerializerFeatures(SerializerFeature.WriteDateUseDateFormat)
            指定全局Date字段的默认序列化格式。
    

这三种方式存在着优先级:方式二 > 方式一 > 方式三,当前一级出现的时候,会直接覆盖掉下一层的配置,具体细看::pringBoot使用fastjosn作为消息转换器、fastjosn对日期的处理、自定义序列化器解决SerializerFeature兼容问题

对此真的没想到,然后通过一段操作,发现是序列化的问题!!!---哭了
原本是不想通过JSONFieLId来对一个个字段进行指定的操作,嫌弃麻烦,就通过消息HttpMessageConverter操作,注入到@bean中,虽然经过一波查询,感觉到参数模型传递错误的bug,但是实在排查不出来,这个在序列化的时候fastjson对此作了特殊处理,因此可以保持原样。而改换springdoc时,此处传入的class却是String! 而fastjson默认会对String进行处理,加上转义符号,因此导致最终的结果出现异常。),真没想到是这种大无语事件,对此我们有两种方式解决:
//

  1. 换成Jackson的converter(springboot默认就是Jackson)。
  2. FastJsonHttpMessageConverter:自定义一个StringSerializer,覆盖掉fastjson的默认的StringSerializer

由于实在太懒了,决定自定义一个序列化的,覆盖掉原来的操作。

public class MyStringSerializer implements ObjectSerializer {
   
   
    public static final MyStringSerializer instance = new MyStringSerializer();
    @Override
    public void write(JSONSerializer serializer, Object object, Object fieldName, Type fieldType, int features) throws IOException {
   
   
        SerializeWriter out = serializer.getWriter();
        out.write(object.toString());
    }
}

然后在FastJsonHttpMessageConverter的配置文件中,如下使用
fastJsonConfig.getSerializeConfig().put(String.class,MyStringSerializer.instance);

最终取得成功,感动死我了!!!!!!

image.png

参数还没修改见谅,就此结束,大家可以参考下,别踩雷了!!!

相关文章
|
关系型数据库 MySQL Nacos
nacos数据库使用PostgreSQL及集群配置
从Nacos2.2版本开始,Nacos提供了数据源扩展插件,以便让需要进行其他数据库适配的用户自己编写插件来保存数据。
|
Java Spring
Spring Boot3整合knife4j(swagger3)
Spring Boot3整合knife4j(swagger3)
4722 1
|
8月前
|
消息中间件 NoSQL Java
spring boot2升级boot3指南
本文介绍了如何将Spring Boot 2.x升级至Spring Boot 3.x,涵盖使用OpenRewrite自动化重构工具进行代码转换、依赖版本升级、配置属性调整及常见问题处理等内容,帮助开发者高效完成升级工作。
2731 7
|
9月前
|
Java 测试技术
Java浮点类型详解:使用与区别
Java中的浮点类型主要包括float和double,它们在内存占用、精度范围和使用场景上有显著差异。float占用4字节,提供约6-7位有效数字;double占用8字节,提供约15-16位有效数字。float适合内存敏感或精度要求不高的场景,而double精度更高,是Java默认的浮点类型,推荐在大多数情况下使用。两者都存在精度限制,不能用于需要精确计算的金融领域。比较浮点数时应使用误差范围或BigDecimal类。科学计算和工程计算通常使用double,而金融计算应使用BigDecimal。
3365 102
|
前端开发 Java Nacos
🛡️Spring Boot 3 整合 Spring Cloud Gateway 工程实践
本文介绍了如何使用Spring Cloud Alibaba 2023.0.0.0技术栈构建微服务网关,以应对微服务架构中流量治理与安全管控的复杂性。通过一个包含鉴权服务、文件服务和主服务的项目,详细讲解了网关的整合与功能开发。首先,通过统一路由配置,将所有请求集中到网关进行管理;其次,实现了限流防刷功能,防止恶意刷接口;最后,添加了登录鉴权机制,确保用户身份验证。整个过程结合Nacos注册中心,确保服务注册与配置管理的高效性。通过这些实践,帮助开发者更好地理解和应用微服务网关。
2417 0
🛡️Spring Boot 3 整合 Spring Cloud Gateway 工程实践
|
Java Spring
spring-doc报错Unable to render this definition
spring-doc报错Unable to render this definition
1019 1
|
Java API 开发者
Spring Boot与OpenAPI的集成
Spring Boot与OpenAPI的集成
|
存储 分布式数据库 Apache
【Flink】Flink的Checkpoint 存在哪里?
【4月更文挑战第19天】【Flink】Flink的Checkpoint 存在哪里?
|
安全 Java API
技术笔记:SpringBoot集成Swagger3.0(详细)
技术笔记:SpringBoot集成Swagger3.0(详细)
|
Java Spring
【已解决】Failed to start bean ‘documentationPluginsBootstrapper‘; nested exception .lang.NullPointerEx
【已解决】Failed to start bean ‘documentationPluginsBootstrapper‘; nested exception .lang.NullPointerEx
708 0

热门文章

最新文章