Rumah  >  Artikel  >  Java  >  Bagaimana untuk menyelesaikan masalah bersiri dan penyahserikatan Json dalam SpringBoot

Bagaimana untuk menyelesaikan masalah bersiri dan penyahserikatan Json dalam SpringBoot

WBOY
WBOYke hadapan
2023-05-12 16:07:06724semak imbas

Control json serialization/deserialisasi

1 Penggunaan @JsonIgnoreProperties

@JsonIgnoreProperties(value = { "prop1","prop2" })

digunakan untuk mengubah suai kelas Pojo dan mengabaikan sifat yang ditentukan semasa bersiri dan deserialisasi diabaikan.

@JsonIgnoreProperties(ignoreUnknown = true)

digunakan untuk mengubah suai kelas Pojo dan mengabaikan atribut yang tidak boleh ditetapkan semasa penyahserikatan, termasuk yang tidak boleh ditetapkan dalam pembina dan tidak mempunyai kaedah penetap yang sepadan.

2 . @JsonProperty anotasi

Jika nama medan json tidak konsisten dengan nama sifat Pojo, anda boleh menggunakan @JsonProperty untuk menganotasi kaedah getter() atau setter() ini menetapkan json yang sepadan Selain itu, @JsonProperty sering digunakan untuk menganotasi parameter rasmi pembina Pada masa ini, pembina harus dianotasi dengan @JsonCreator.

3 @JsonCreator anotasi

Jika Pojo definisi kelas mempunyai pembina Parameter, tetapi jika tiada pembina tanpa parameter disediakan, ralat akan dilaporkan semasa penyahserikatan Terdapat dua kaedah:

  • Kaedah 1: Tambah pembina tanpa parameter

    <.>
  • Kaedah 2: Tambahkan anotasi @JsonCreator pada pembina ini dengan parameter dan parameter perlu dianotasi dengan @JsonProperty.

4. @JsonSetter dan @JsonGetter anotasi

Jika nama medan json tidak konsisten dengan nama sifat Pojo, anda boleh menggunakan @JsonGetter untuk menganotasi getter() dan @JsonSetter untuk menganotasi kaedah setter() ini Setiap anotasi boleh menentukan nama sifat kedua-dua anotasi boleh digantikan dengan @JsonProperty.

5 @JsonAnySetter anotasi

Nama sifat objek umum ditentukan, seperti objek Kereta , terdapat namanya. atribut seperti jenama/harga, tetapi kadangkala kita juga perlu menetapkan beberapa atribut lanjutan untuk objek Kereta Nama atribut lanjutan ini belum ditentukan Peta05ad6303f369fc4ccec4412db2772d19 atribut. V. Untuk menyahsiri atribut ini dalam data json ke dalam Peta kelas, anda perlu menambah kaedah penetap K/V pada kelas dan kaedah penetap ini mesti dianotasi dengan @JsonAnySetter.

public class Car {
    public String brand;
    private Map<String, String> properties;
 
    @JsonAnySetter
    public void add(String key, String value) {
        properties.put(key, value);
    }
}

Setelah kelas ditambahkan dengan @JsonAnySetter, data json berikut boleh dinyahsiri ke dalam Peta:

{
"brand":"Benz",
"attr2":"val2",
"attr1":"val1"
}

6 Anotasi @JsonAnyGetter

sepadan dengan anotasi @JsonAnySetter untuk menukar kelas Untuk menyerikan atribut Map K/V ke dalam json, anda perlu menambahkan kaedah @JsonAnyGetter ke kelas Kaedah ini boleh mengembalikan peta KV secara terus

public class Car {
    public String brand;
    private Map<String, String> properties;
 
    @JsonAnyGetter
    public Map<String, String> getProperties() {
        return properties;
    }
}

Json bersiri ialah:

{
"brand":"Benz",
"attr2":"val2",
"attr1":"val1"
}

7. @JsonFormat anotasi

biasanya menentukan format masa yang digunakan untuk bersiri sifat Tarikh/Masa.

public class Event {
    public String name;
 
    @JsonFormat(
      shape = JsonFormat.Shape.STRING, pattern = "dd-MM-yyyy hh:mm:ss")
    public Date eventDate;
}

8 >@JsonSerialize anotasi Fungsi bersiri khas boleh ditetapkan untuk atribut kelas Anotasi @JsonDeserialize digunakan untuk menyesuaikan fungsi penyahserikatan untuk atribut json

Peraturan siri SpringBoot

<.> Lalai
  • Include.Include.ALWAYS

    Atribut ialah nilai lalai dan tidak bersiri
  • Include.NON_DEFAULT

    Atribut kosong ("" ) atau NULL. Jangan sirikan
  • Include.NON_EMPTY

    Atribut ialah NULL Jangan sirikan
  • Include.NON_NULL 1. Tetapan global

    rreee
  • atau
/**
 * 〈返回json空值去掉null和""〉 〈功能详细描述〉
 * 
 * @author gogym
 * @version 2017年10月13日
 * @see JacksonConfig
 * @since
 */
@Configuration
public class JacksonConfig
{
    @Bean
    @Primary
    @ConditionalOnMissingBean(ObjectMapper.class)
    public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder)
    {
        ObjectMapper objectMapper = builder.createXmlMapper(false).build();
        // 通过该方法对mapper对象进行设置,所有序列化的对象都将按改规则进行系列化
        // Include.Include.ALWAYS 默认
        // Include.NON_DEFAULT 属性为默认值不序列化
        // Include.NON_EMPTY 属性为 空("") 或者为 NULL 都不序列化,则返回的json是没有这个字段的。这样对移动端会更省流量
        // Include.NON_NULL 属性为NULL 不序列化,就是为null的字段不参加序列化
        //objectMapper.setSerializationInclusion(Include.NON_EMPTY);
        objectMapper.setSerializationInclusion(JsonInclude.Include.NON_EMPTY);
        return objectMapper;
    }
}

2. Tetapan setempat

Tambahkan anotasi pada kelas entiti atau medan yang perlu ditetapkan

spring.jackson.default-property-inclusion=non_null
spring:
  jackson:
    default-property-inclusion: non_null

3 (1) , untuk menyesuaikan kelas alat bersiri, anda perlu melaksanakan StdSerializer8742468051c85b06f0a0af9e3e506b5c atau JsonSerializer8742468051c85b06f0a0af9e3e506b5c

@JsonInclude(Include.NON_NULL)

(2) Gunakan anotasi untuk bertindak pada kelas entiti

public class ClientObjectSerialize extends JsonSerializer<CreditBorrowerRepaymentRequestDto>{
 @Override
 public void serialize(CreditBorrowerRepaymentRequestDto dto, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException, JsonProcessingException {
 
  jsonGenerator.writeStartObject();
  try {
   Field[] fields = dto.getClass().getDeclaredFields();
   for (Field field : fields) {
    field.setAccessible(true);
    if(null == field.get(dto)){
     continue; 
    }
    jsonGenerator.writeFieldName(field.getName());
    jsonGenerator.writeObject(field.get(dto));
   }
  } catch (Exception e) {
   e.printStackTrace();
  }
  jsonGenerator.writeEndObject();
 }
}

(3 ) Boleh bertindak pada medan objek entiti, memproses nilai NULL atau menukar

@JsonSerialize(using = ClientObjectSerialize.class)
public class CreditBorrowerRepaymentRequestDto{
}

4 Sesuaikan siri penukaran nol global

SpringBoot mengembalikan pemprosesan nilai nol dalam data Json dan menukar nilai nol jenis rentetan. Tukar kepada "", tukar nilai null jenis tatasusunan koleksi kepada [], tukar nilai null jenis data primitif kepada 0, tukar nilai null jenis Boolean kepada palsu dan tukar nilai null objek entiti kepada {}.

(1)

Pensiri nilai nol tersuai

@JsonSerialize(using = ClientStringSerialize.class)
private String name;
 
@JsonSerialize(using = ClientDtaeSerialize.class)
private Date date;
public class ClientStringSerialize extends JsonSerializer<String> {
 
 @Override
 public void serialize(String string, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException {
 
  if(string == null){
   jsonGenerator.writeString(string + "[NULL]");
  }else{
   jsonGenerator.writeString(string);
  }
 }
}
 
public class ClientDtaeSerialize extends JsonSerializer<Date> {
 @Override
 public void serialize(Date createDate, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException {
  jsonGenerator.writeString(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(createDate));
 }
}

(2)

Pengubah suai siri

import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.databind.JsonSerializer;
import com.fasterxml.jackson.databind.SerializerProvider;
import java.io.IOException;
/**
 * 自定义null值序列化处理器
 */
public class CustomizeNullJsonSerializer {
 
 /**
  * 处理数组集合类型的null值
  */
 public static class NullArrayJsonSerializer extends JsonSerializer<Object> {
  @Override
  public void serialize(Object value, JsonGenerator jsonGenerator, 
    SerializerProvider serializerProvider) throws IOException {
   jsonGenerator.writeStartArray();
   jsonGenerator.writeEndArray();
  }
 }
 
 /**
  * 处理字符串类型的null值
  */
 public static class NullStringJsonSerializer extends JsonSerializer<Object> {
  @Override
  public void serialize(Object value, JsonGenerator jsonGenerator, 
    SerializerProvider serializerProvider) throws IOException {
   jsonGenerator.writeString("");
  }
 }
 
 /**
  * 处理数值类型的null值
  */
 public static class NullNumberJsonSerializer extends JsonSerializer<Object> {
  @Override
  public void serialize(Object value, JsonGenerator jsonGenerator, 
        SerializerProvider serializerProvider) throws IOException {
   jsonGenerator.writeNumber(0);
  }
 }
 
 /**
  * 处理boolean类型的null值
  */
 public static class NullBooleanJsonSerializer extends JsonSerializer<Object> {
  @Override
  public void serialize(Object value, JsonGenerator jsonGenerator, 
        SerializerProvider serializerProvider) throws IOException {
   jsonGenerator.writeBoolean(false);
  }
 }
 
 /**
  * 处理实体对象类型的null值
  */
 public static class NullObjectJsonSerializer extends JsonSerializer<Object> {
  @Override
  public void serialize(Object value, JsonGenerator jsonGenerator, 
        SerializerProvider serializerProvider) throws IOException {
   jsonGenerator.writeStartObject();
   jsonGenerator.writeEndObject();
  }
 }
}
(3)

Konfigurasikan entiti Jackson

import com.fasterxml.jackson.databind.BeanDescription;
import com.fasterxml.jackson.databind.SerializationConfig;
import com.fasterxml.jackson.databind.ser.BeanPropertyWriter;
import com.fasterxml.jackson.databind.ser.BeanSerializerModifier;
import java.util.Collection;
import java.util.List;
 
/**
 * <pre class="brush:php;toolbar:false">
 * 此modifier主要做的事情为:
 * 1.当序列化类型为数组集合时,当值为null时,序列化成[]
 * 2.String类型值序列化为""
 *
 * 
*/ public class MyBeanSerializerModifier extends BeanSerializerModifier { @Override public List changeProperties(SerializationConfig config, BeanDescription beanDesc, List beanProperties) { // 循环所有的beanPropertyWriter for (int i = 0; i < beanProperties.size(); i++) { BeanPropertyWriter writer = beanProperties.get(i); // 判断字段的类型,如果是数组或集合则注册nullSerializer if (isArrayType(writer)) { // 给writer注册一个自己的nullSerializer writer.assignNullSerializer(new CustomizeNullJsonSerializer.NullArrayJsonSerializer()); } if (isStringType(writer)) { writer.assignNullSerializer(new CustomizeNullJsonSerializer.NullStringJsonSerializer()); } } return beanProperties; } /** * 是否是数组 */ private boolean isArrayType(BeanPropertyWriter writer) { Class clazz = writer.getType().getRawClass(); return clazz.isArray() || Collection.class.isAssignableFrom(clazz); } /** * 是否是String */ private boolean isStringType(BeanPropertyWriter writer) { Class clazz = writer.getType().getRawClass(); return CharSequence.class.isAssignableFrom(clazz) || Character.class.isAssignableFrom(clazz); } /** * 是否是数值类型 */ private boolean isNumberType(BeanPropertyWriter writer) { Class clazz = writer.getType().getRawClass(); return Number.class.isAssignableFrom(clazz); } /** * 是否是boolean */ private boolean isBooleanType(BeanPropertyWriter writer) { Class clazz = writer.getType().getRawClass(); return clazz.equals(Boolean.class); } }

Atas ialah kandungan terperinci Bagaimana untuk menyelesaikan masalah bersiri dan penyahserikatan Json dalam SpringBoot. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam