json、xstream转换器及配置全局jackson

fastJson 转换器

// 反序列化
public class SexFastJsonSerialize implements ObjectDeserializer{}

// 序列化
public class SexFastJsonSerialize implements ObjectSerializer {

    @Override
    public void write(JSONSerializer jsonSerializer, Object object, Object fieldName, Type fieldType, int features) throws IOException {
        // 强制把值转换为String
        String formCode = (String) object;
        // 序列化为自定义的name属性,输出就行
        jsonSerializer.out.writeString(HosGenderType.getHosGenderTypeByFormCode(formCode).getCode());
    }
}

Jackson 序列化转换器


// 反序列化
public class SexJacksonSerialize implements JsonDeserializer{}

// 序列化
public class SexJacksonSerialize extends JsonSerializer<String> {


    @Override
    public void serialize(String value, JsonGenerator gen, SerializerProvider serializerProvider) throws IOException {
        gen.writeString(HosGenderType.getHosGenderTypeByFormCode(value).getCode());
    }
}

json转换器使用实例

    @JSONField(serializeUsing = SexFastJsonSerialize.class)
    @JsonSerialize(using = SexJacksonSerialize.class)

xStream转换器

/***
 *  xml 字段转换器
 * @author qb
 * @since 2023/6/2 8:34
 * @version 1.0
 */
public class SexConverter implements Converter {

    @Override
    public boolean canConvert(Class type) {
        return String.class.isAssignableFrom(type);
    }

    /**
     * 值转换器
     * @param o                     /
     * @param writer                /
     * @param marshallingContext    /
     */
    @Override
    public void marshal(Object o, HierarchicalStreamWriter writer, MarshallingContext marshallingContext) {
        String cData = (String) o;
        writer.setValue(HosGenderType.getHosGenderTypeByToCode(cData).getCode());
    }

    /**
     * Convert textual data back into an object.
     *
     * @param reader  The stream to read the text from.
     * @param context
     * @return The resulting object.
     */
    @Override
    public Object unmarshal(HierarchicalStreamReader reader, UnmarshallingContext context) {
        return reader.getValue();
    }
}

xStream 使用

@XStreamConverter(value = SexConverter.class)

全局jackson配置

遇到了一个bug,在使用jackson的别名注解时,swagger生成的参数不是别名而是实体参数,还是重复的,所以便使用了全局jackson统一使用fastjson的名称序列化


@Configuration
@AutoConfigureAfter(SwaggerConfiguration.class)
public class JacksonConfiguration {

    @Bean
    public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {
        ObjectMapper objectMapper = builder.createXmlMapper(false).build();
        objectMapper.configOverride(String.class).setSetterInfo(JsonSetter.Value.forValueNulls(Nulls.AS_EMPTY));
        objectMapper.setAnnotationIntrospector(new JacksonAnnotationIntrospector() {
            @Override
            public boolean isAnnotationBundle(Annotation ann) {
                if (ann.annotationType() == JSONField.class) {
                    return true;
                }
                return super.isAnnotationBundle(ann);
            }
            @Override
            public PropertyName findNameForSerialization(Annotated a) {
                PropertyName nameForSerialization = super.findNameForSerialization(a);
                if (nameForSerialization == null || nameForSerialization == PropertyName.USE_DEFAULT) {
                    JSONField jsonField = _findAnnotation(a, JSONField.class);
                    if (jsonField != null) {
                        return PropertyName.construct(jsonField.name());
                    }

                }
                return nameForSerialization;
            }

            @Override
            public PropertyName findNameForDeserialization(Annotated a) {
                PropertyName nameForDeserialization = super.findNameForDeserialization(a);
                if (nameForDeserialization == null || nameForDeserialization == PropertyName.USE_DEFAULT) {
                    JSONField jsonField = _findAnnotation(a, JSONField.class);
                    if (jsonField != null) {
                        return PropertyName.construct(jsonField.name());
                    }
                }
                return nameForDeserialization;
            }
        });
        return objectMapper;
    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 目前有许多Java工具可以用于JSON和XML之间的转换。 1. Jackson库:Jackson是一个功能强大的Java库,可用于JSON和XML之间的转换。它提供了几个简单而强大的API,使转换变得容易。使用Jackson,您可以将JSON数据解析为Java对象,并将Java对象序列化为JSON或XML格式。 2. Gson库:Gson是Google提供的另一个流行的Java库,可用于JSON和XML的转换。它提供了简单的API,可以轻松地将JSON数据解析为Java对象,并将Java对象序列化为JSON或XML。 3. JAXB(Java Architecture for XML Binding):JAXB是Java中用于处理XML数据绑定的标准库。它允许您将Java对象与XML文档之间进行转换。通过使用JAXB提供的注解和API,您可以将XML数据映射到Java对象,并将Java对象序列化为XML格式。 4. XStream库:XStream是一个简单的Java库,可用于将Java对象序列化为XML格式,并将XML反序列化为Java对象。它提供了简单的API和注解来指定对象的转换规则。 无论您选择哪个工具,都应该考虑以下因素:易用性,性能,对复杂数据类型的支持以及与您的项目的兼容性。 ### 回答2: 在Java中,我们可以使用许多工具来进行JSON到XML和XML到JSON的转换。以下是一些常用的工具: 1. Jackson库:Jackson是一个功能强大的Java库,提供了许多用于处理JSON和XML的工具。它可以用于将JSON转换为XML和将XML转换为JSON。它提供了一套简单易用的API,可以轻松地在Java应用程序中进行转换操作。 2. Gson库:Gson是一个由Google开发的Java库,用于处理JSON数据。它提供了将JSON转换为XML和将XML转换为JSON的功能。Gson库使用简单,并且具有广泛的社区支持。 3. XStream库:XStream是一个流行的Java库,用于将Java对象序列化为XML或JSON。它提供了方便的API,可以轻松地在Java应用程序中进行转换操作。XStream支持自定义转换器和注释,可以满足各种转换需求。 4. JAXB库:JAXB是Java体系结构的一部分,用于将Java对象转换为XML和将XML转换为Java对象。它提供了一组注解,可以方便地在Java类和XML元素之间进行映射。 这些工具在Java开发中被广泛使用,并且具有成熟的文档和社区支持。根据具体的需求和偏好,选择适合自己项目的工具进行JSON和XML之间的转换。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值