Java implementa la conversión de cadenas y objetos JSON

Java implementa la conversión de cadenas y objetos JSON

Consejos antes de ver:

La versión de IDEA utilizada en este artículo es la última 2019.1, y la versión JDK es 1.8.0_141.

1. Jackon ObjectMapper

Paquetes jar relacionados con la referencia

	<dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-annotations</artifactId>
      <version>2.11.2</version>
    </dependency>

    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-databind</artifactId>
      <version>2.11.2</version>
    </dependency>

Entidad Person.java

package testJsonToEntity;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;

@JsonPropertyOrder(value = {
    
    "ID","name","age"})
@JsonIgnoreProperties(ignoreUnknown = true)
public class Person {
    
    

    @JsonProperty("ID")
    private String id;

    @JsonInclude(JsonInclude.Include.NON_NULL)
    private String name;

    private int age;

    public String getId() {
    
    
        return id;
    }

    public void setId(String id) {
    
    
        this.id = id;
    }

    public String getName() {
    
    
        return name;
    }

    public void setName(String name) {
    
    
        this.name = name;
    }

    public int getAge() {
    
    
        return age;
    }

    public void setAge(int age) {
    
    
        this.age = age;
    }

    @Override
    public String toString() {
    
    
        return "Person{" +
                "id='" + id + '\'' +
                ", name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

Nota :

  1. @JsonPropertyOrder Esta anotación se usa para ordenar propiedades.

  2. @JsonIgnoreProperties (ignoreUnknown = true), después de escribir esta anotación en la clase, los campos que no existen en la clase serán ignorados.

  3. @JsonProperty Esta anotación se usa en propiedades, y su función es serializar el nombre de la propiedad a otro nombre, como serializar la propiedad trueName a nombre.

  4. El rol de @JsonInclude (Include.NON_NULL): el campo en el que la entidad jackson convierte json en NULL no participará en la serialización (es decir, no se mostrará)

Clase de prueba Test.java

package testJsonToEntity;

import com.fasterxml.jackson.databind.ObjectMapper;

public class Test {
    
    

    private static ObjectMapper mapper = new ObjectMapper();

    public static void main(String[] args) throws Exception {
    
    

        Person p = new Person();
        p.setId("1111");
        p.setAge(18);
        String jsonStr = mapper.writeValueAsString(p);
        System.out.println(jsonStr);

        String json = "{\"Id\":\"1111\",\"age\":18,\"sex\":\"male\"}";
        Person p1 = mapper.readValue(json, Person.class);
        System.out.println(p1.toString());
    }
}

El resultado es

Inserte la descripción de la imagen aquí

Supongo que te gusta

Origin blog.csdn.net/weixin_43611145/article/details/108624521
Recomendado
Clasificación