jackson 序列化配置详解

         //这个特性,决定了解析器是否将自动关闭那些不属于parser自己的输入源。
        // 如果禁止,则调用应用不得不分别去关闭那些被用来创建parser的基础输入流InputStream和reader;
        //默认是true
        objectMapper.configure(JsonParser.Feature.AUTO_CLOSE_SOURCE, true);
        //是否允许解析使用Java/C++ 样式的注释(包括'/'+'*' 和'//' 变量)
        objectMapper.configure(JsonParser.Feature.ALLOW_COMMENTS, true);
 
        //设置为true时,属性名称不带双引号
        objectMapper.configure(JsonGenerator.Feature.QUOTE_FIELD_NAMES, false);
        //反序列化是是否允许属性名称不带双引号
        objectMapper.configure(JsonParser.Feature.ALLOW_UNQUOTED_FIELD_NAMES, true);
 
        //是否允许单引号来包住属性名称和字符串值
        objectMapper.configure(JsonParser.Feature.ALLOW_SINGLE_QUOTES, true);
 
        //是否允许JSON字符串包含非引号控制字符(值小于32的ASCII字符,包含制表符和换行符)
        objectMapper.configure(JsonParser.Feature.ALLOW_UNQUOTED_CONTROL_CHARS, true);
 
        //是否允许JSON整数以多个0开始
        objectMapper.configure(JsonParser.Feature.ALLOW_NUMERIC_LEADING_ZEROS, true);
 
        //null的属性不序列化
        objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
 
        //按字母顺序排序属性,默认false
        objectMapper.configure(MapperFeature.SORT_PROPERTIES_ALPHABETICALLY,true);
 
        //是否以类名作为根元素,可以通过@JsonRootName来自定义根元素名称,默认false
        objectMapper.configure(SerializationFeature.WRAP_ROOT_VALUE,true);
 
        //是否缩放排列输出,默认false
        objectMapper.configure(SerializationFeature.INDENT_OUTPUT,false);
 
        //序列化Date日期时以timestamps输出,默认true
        objectMapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS,true);
 
        //序列化枚举是否以toString()来输出,默认false,即默认以name()来输出
        objectMapper.configure(SerializationFeature.WRITE_ENUMS_USING_TO_STRING, true);
 
        //序列化枚举是否以ordinal()来输出,默认false
        objectMapper.configure(SerializationFeature.WRITE_ENUMS_USING_INDEX,false);
 
        //序列化单元素数组时不以数组来输出,默认false
        objectMapper.configure(SerializationFeature.WRITE_ENUMS_USING_TO_STRING,true);
 
        //序列化Map时对key进行排序操作,默认false
        objectMapper.configure(SerializationFeature.ORDER_MAP_ENTRIES_BY_KEYS,true);
 
        //序列化char[]时以json数组输出,默认false
        objectMapper.configure(SerializationFeature.WRITE_CHAR_ARRAYS_AS_JSON_ARRAYS,true);
 
        //序列化BigDecimal时是输出原始数字还是科学计数,默认false,即以toPlainString()科学计数方式来输出
        objectMapper.configure(SerializationFeature.WRITE_BIGDECIMAL_AS_PLAIN,true);

 

@JsonFormat(pattern = "yyyy-MM-dd'T' HH:mm:ss:SSS'Z'",timezone = "GMT+8")
时间格式注解 类型必须是Date,否则不生效

 

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中,可以使用Jackson库来进行自定义序列化和反序列化Jackson是一个流行的JSON处理库,提供了灵活的方式来自定义对象的序列化和反序列化行为。 要自定义Jackson序列化和反序列化,可以通过实现`JsonSerializer`和`JsonDeserializer`接口来创建自定义的序列化器和反序列化器。 下面是一个示例代码,展示了如何使用自定义的Jackson序列化和反序列化一个`Person`类: ```java import com.fasterxml.jackson.core.JsonGenerator; import com.fasterxml.jackson.core.JsonParser; import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.*; import com.fasterxml.jackson.databind.module.SimpleModule; import java.io.IOException; public class Person { private String name; private int age; // 构造函数 public Person(String name, int age) { this.name = name; this.age = age; } // 其他方法和属性... // 自定义序列化器 public static class PersonSerializer extends JsonSerializer<Person> { @Override public void serialize(Person person, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException, JsonProcessingException { jsonGenerator.writeStartObject(); jsonGenerator.writeStringField("personName", person.name); jsonGenerator.writeNumberField("personAge", person.age); jsonGenerator.writeEndObject(); } } // 自定义反序列化器 public static class PersonDeserializer extends JsonDeserializer<Person> { @Override public Person deserialize(JsonParser jsonParser, DeserializationContext deserializationContext) throws IOException, JsonProcessingException { JsonNode node = jsonParser.getCodec().readTree(jsonParser); String name = node.get("personName").asText(); int age = node.get("personAge").asInt(); return new Person(name, age); } } public static void main(String[] args) throws JsonProcessingException { ObjectMapper objectMapper = new ObjectMapper(); SimpleModule module = new SimpleModule(); module.addSerializer(Person.class, new PersonSerializer()); module.addDeserializer(Person.class, new PersonDeserializer()); objectMapper.registerModule(module); Person person = new Person("Alice", 25); String json = objectMapper.writeValueAsString(person); System.out.println(json); // 输出:{"personName":"Alice","personAge":25} Person deserializedPerson = objectMapper.readValue(json, Person.class); System.out.println(deserializedPerson.getName()); // 输出:Alice System.out.println(deserializedPerson.getAge()); // 输出:25 } } ``` 在上面的示例中,我们定义了一个`Person`类,并在类内部定义了`PersonSerializer`和`PersonDeserializer`作为自定义的序列化器和反序列化器。在`PersonSerializer`中,我们将`Person`对象的属性转换为JSON对象。在`PersonDeserializer`中,我们从JSON对象中读取属性并重新构造`Person`对象。 在`main`方法中,我们创建了一个`ObjectMapper`对象,并注册了自定义的序列化器和反序列化器。然后,我们可以使用`ObjectMapper`将`Person`对象序列化为JSON字符串,并将JSON字符串反序列化为`Person`对象。 通过自定义Jackson序列化器和反序列化器,我们可以灵活地控制对象的序列化和反序列化过程,实现自定义的转换逻辑。 希望这个示例能帮助你理解如何在Java中自定义Jackson序列化和反序列化
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值