Utilisation de noms différents pour les propriétés JSON lors de la sérialisation et de la désérialisation dans Jackson
La sérialisation et la désérialisation nécessitent souvent des noms de champs correspondants entre les classes JSON et Java. Cependant, il peut arriver que vous souhaitiez utiliser des noms différents pour le même champ au cours de ces processus. Par exemple, considérons la classe Coordonnées suivante :
<code class="java">class Coordinates { int red; }</code>
Dans ce scénario, vous souhaiterez peut-être le format JSON suivant pour la désérialisation :
<code class="json">{ "red": 12 }</code>
Simultanément, vous préférerez peut-être un format JSON différent pour la sérialisation :
<code class="json">{ "r": 12 }</code>
Dans un premier temps, tenter d'utiliser les annotations @JsonProperty sur les méthodes getter et setter peut entraîner une exception :
<code class="java">@JsonProperty("r") public byte getRed() { return red; } @JsonProperty("red") public void setRed(byte red) { this.red = red; }</code>
Cependant, ce problème peut être corrigé en s'assurant que les noms de méthodes sont distincts. Par exemple :
<code class="java">public byte getR() { return red; } public void setRed(byte red) { this.red = red; }</code>
En fournissant différents noms de méthodes, Jackson les interprète comme des champs distincts. Le code de test suivant démontre l'utilisation réussie de cette approche :
<code class="java">Coordinates c = new Coordinates(); c.setRed((byte) 5); ObjectMapper mapper = new ObjectMapper(); System.out.println("Serialization: " + mapper.writeValueAsString(c)); Coordinates r = mapper.readValue("{\"red\":25}", Coordinates.class); System.out.println("Deserialization: " + r.getR());</code>
Le résultat attendu est :
Serialization: {"r":5} Deserialization: 25
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!