Skip to content

本功能希望实现json方式的统一管理和扩展和灵活一键切换功能,简化接入方式和打通各个json的隔阂,支持类型JSONPath、fastjson、Jackson、json read/set ...

License

JsonMs/marcus-json

Repository files navigation

Marcus Json

JDK MAVEN Spring Boot

本功能希望实现json方式的统一管理和扩展和灵活一键切换功能,简化接入方式和打通各个json的隔阂,实现类似type-c接口一样的通用能力 对于已经接入其他json的,可以先使用对应json类型的实现替换原来的方法,然后实现丝滑切换不同的json类型方式,也支持扩展自己的json类型

Repobeats analytics image

如何添加

基础组建功能版本api,封装了对象、数组、json文件、json路径功能,支持自定义扩展json组件能力

Step1: 导入功能模块

基础api版本

<dependency>
    <groupId>io.github.jsonms</groupId>
    <artifactId>marcus-json-api</artifactId>
    <version>1.0.1</version>
</dependency>

springboot 启动器版本

<dependency>
    <groupId>io.github.jsonms</groupId>
    <artifactId>marcus-json-spring-boot-starter</artifactId>
    <version>1.0.1</version>
</dependency>

Step2: 指定使用的json类型 (可选)

只能在一个类中使用,如果多个类会有相应提示信息,默认使用jackson

@AutoJson(JsonEnum.JACKSON)

或者

spring:
    json:
      type: jackson

扩展功能

借鉴其他优秀框架的spi能力,支持spi的文件和注解配置,实现类可以基于如下两个类扩展

原始接口:cn.marcus.json.api.JsonFacade

抽象类(自实现jsonpath、json Reader/Write功能): cn.marcus.json.api.AbstractJsonFacade

方式1:注解(推荐)

使用@Extension("jackson")放到实现类上面,括号填入json类型别名即可

方式2:文件配置

需要在在resources下新建META-INF/services/json/,建文件 cn.marcus.json.api.JsonFacade如图

├── resources
    └── META-INF
        └── service
            └── json
                └── cn.marcus.json.api.JsonFacade

文件名cn.marcus.json.api.JsonFacade文件里面格式

扩展json类型:扩展实现类,中间通过=区分开 如下

fastjson2=cn.marcus.json.api.support.FastJson2Handler

About

本功能希望实现json方式的统一管理和扩展和灵活一键切换功能,简化接入方式和打通各个json的隔阂,支持类型JSONPath、fastjson、Jackson、json read/set ...

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Languages