继承JsonSerializer<T>抽象类实现自定义序列化器

本文介绍了一个自定义的GeoJSON点序列化器和反序列化器的实现方式,通过继承JsonSerializer和JsonDeserializer接口并重写相应的方法,实现了对GeoJSON点对象的有效序列化与反序列化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 自定义序列化器需要继承 JsonSerializer 接口,泛型为需要被序列化的对象 重写 serialize() 方法
  2. 在需要序列化的实体类上加上注解 @JsonSerialize(using = TemplateSerialize.class)
  3. 指定序列化器
public class GeoJsonPointSerializer extends JsonSerializer<GeoJsonPoint> {
    @Override
    public void serialize(GeoJsonPoint value, JsonGenerator gen, SerializerProvider serializers) throws IOException {
        ser(value, gen, serializers, null);
    }


    @Override
    public void serializeWithType(GeoJsonPoint value, JsonGenerator gen, SerializerProvider serializers, TypeSerializer typeSer) throws IOException {
        ser(value, gen, serializers, typeSer);
    }

    private void ser(GeoJsonPoint value, JsonGenerator gen, SerializerProvider serializers, TypeSerializer typeSer) throws IOException {

        gen.writeStartArray();
        if (value != null) {
            gen.writeNumber(value.getX());
            gen.writeNumber(value.getY());
        }
        gen.writeEndArray();
    }
}

public class GeoJsonPointDeserializer extends JsonDeserializer<GeoJsonPoint> {

    @Override
    public GeoJsonPoint deserialize(JsonParser parser, DeserializationContext context) throws IOException, JsonProcessingException {
        return der(parser, context, null);
    }


    @Override
    public Object deserializeWithType(JsonParser p, DeserializationContext ctxt, TypeDeserializer typeDeserializer) throws IOException {
        return der(p, ctxt, typeDeserializer);
    }

    private GeoJsonPoint der(JsonParser parser, DeserializationContext context, TypeDeserializer typeDeserializer) throws IOException {
        if (parser.isExpectedStartArrayToken()) {
            JsonToken t = parser.nextToken();
            if (t == JsonToken.END_ARRAY) {
                return null;
            }
            GeoJsonPoint result;
            if (t == JsonToken.VALUE_NUMBER_FLOAT) {
                double x = parser.getDoubleValue();
                t = parser.nextToken();
                if (t == JsonToken.VALUE_NUMBER_FLOAT) {
                    double y = parser.getDoubleValue();
                    result = new GeoJsonPoint(x, y);
                    JsonToken jsonToken = parser.nextToken();
                    if(jsonToken==JsonToken.END_ARRAY){
                        return result;
                    }
                }
            }
        }
        return handleUnexpectedToken(context, parser, "Expected array.");
    }

    @SuppressWarnings("unchecked")
    protected <R> R handleUnexpectedToken(DeserializationContext context,
                                          JsonParser parser, String message, Object... args) throws JsonMappingException {
        try {
            return (R) context.handleUnexpectedToken(handledType(), parser.getCurrentToken(),
                    parser, message, args);

        } catch (JsonMappingException e) {
            throw e;
        } catch (IOException e) {
            throw JsonMappingException.fromUnexpectedIOE(e);
        }
    }
}

package com.kucun.data.entity.DTO; import com.fasterxml.jackson.core.JsonGenerator; import com.fasterxml.jackson.databind.JsonSerializer; import com.fasterxml.jackson.databind.SerializerProvider; import com.fasterxml.jackson.databind.ser.BeanSerializer; import com.fasterxml.jackson.databind.util.NameTransformer; import java.io.IOException; public class FullEntitySerializer extends JsonSerializer<Object> { private final JsonSerializer<Object> defaultSerializer; public FullEntitySerializer(JsonSerializer<Object> defaultSerializer) { this.defaultSerializer = defaultSerializer; } @Override public void serialize(Object value, JsonGenerator gen, SerializerProvider provider) throws IOException { // 默认完整序列化 defaultSerializer.serialize(value, gen, provider); } // 用于处理嵌套序列化 @Override public JsonSerializer<Object> unwrappingSerializer(NameTransformer unwrapper) { return new FullEntitySerializer(defaultSerializer.unwrappingSerializer(unwrapper)); } }ibernate: select user0_.id as id1_9_, user0_.andy as andy2_9_, user0_.name as name3_9_, user0_.pass as pass4_9_, user0_.role as role5_9_ from user user0_ com.fasterxml.jackson.databind.JsonMappingException: Class com.kucun.data.entity.DTO.FullEntitySerializer has no default (no arg) constructor (through reference chain: java.util.HashMap["bancais"]->java.util.ArrayList[0]->com.kucun.data.entity.Bancai$HibernateProxy$q0bc7nh6["kucun"]) at com.fasterxml.jackson.databind.JsonMappingException.from(JsonMappingException.java:295) at com.fasterxml.jackson.databind.SerializerProvider.reportMappingProblem(SerializerProvider.java:1309) at com.fasterxml.jackson.databind.SerializerProvider._createAndCacheUntypedSerializer(SerializerProvider.java:1427) at com.fasterxml.jackson.databind.SerializerProvider.findPrimaryPropertySerializer(SerializerProvider.java:682) at com.fasterxml.jackson.databind.ser.impl.PropertySerializerMap.findAndAddPrimarySerializer(PropertySerializerMap.java:64) at com.fasterxml.jackson.databind.ser.BeanPropertyWriter._findAndAddDynamic(BeanPropertyWriter.java:898) at com.fasterxml.jackson.databind.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:706) at com.fasterxml.jackson.databind.ser.std.BeanSerializerBase.serializeFields(BeanSerializerBase.java:755) at com.fasterxml.jackson.databind.ser.BeanSerializer.serialize(BeanSerializer.java:178) at com.fasterxml.jackson.databind.ser.impl.IndexedListSerializer.serializeContents(IndexedListSerializer.java:119) at com.fasterxml.jackson.databind.ser.impl.IndexedListSerializer.serialize(IndexedListSerializer.java:79) at com.fasterxml.jackson.databind.ser.impl.IndexedListSerializer.serialize(IndexedListSerializer.java:18) at com.fasterxml.jackson.databind.ser.std.MapSerializer.serializeFields(MapSerializer.java:726) at com.fasterxml.jackson.databind.ser.std.MapSerializer.serializeWithoutTypeInfo(MapSerializer.java:681)
最新发布
06-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值