Maison >développement back-end >Golang >Comment utiliser plusieurs balises JSON pour un seul champ de structure dans Go ?

Comment utiliser plusieurs balises JSON pour un seul champ de structure dans Go ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-12-17 03:25:25418parcourir

How to Use Multiple JSON Tags for a Single Struct Field in Go?

Plusieurs balises JSON pour les champs Struct

Dans un scénario où vous recevez des données JSON d'un serveur et devez les désorganiser dans une structure, vous pourriez rencontrer des situations dans lesquelles vous souhaitez représenter les mêmes données avec différentes balises JSON à des fins différentes.

Personnalisation Balises JSON

La balise JSON spécifie le nom du champ utilisé dans la représentation JSON. Par défaut, la balise d'un champ est la même que le nom du champ. Cependant, vous pouvez personnaliser les balises pour modifier les noms utilisés lors de la sérialisation ou de la désérialisation de la structure.

Balise JSON unique

L'utilisation d'une seule balise JSON est simple. Spécifiez simplement la balise souhaitée sous forme de chaîne littérale :

type Foo struct {
    Name string `json:"name"`
    Age  int    `json:"age"`
}

Plusieurs balises JSON

Comme mentionné dans la question, il n'est pas possible d'attacher plusieurs balises JSON directement à un seul champ. Cependant, il existe une technique qui vous permet de contourner cette limitation.

Casting de structure

La solution donnée suggère d'utiliser deux structures qui ont la même disposition de champ. Par exemple :

type Foo struct {
    Name string
    Age  int
}

type Bar struct {
    Name string `json:"employee_name"`
    Age  int    `json:"-"`
}

Ensuite, vous pouvez convertir la structure Foo en structure Bar pour modifier les balises JSON. Cette technique est particulièrement utile lorsque vous avez un grand nombre de champs :

foo := Foo{Name: "Sam", Age: 20}
bar := (*Bar)(unsafe.Pointer(&foo))

Attention

Il est important de noter que la deuxième struct doit être désexportée pour éviter cela d'être accessible en dehors de votre forfait actuel. Cela garantit que le casting est effectué uniquement comme prévu et non accidentellement mal utilisé.

Exemple

Le code suivant illustre la technique de casting mentionnée ci-dessus :

package main

import (
    "encoding/json"
    "fmt"
)

type Foo struct {
    Name string
    Age  int
}

type Bar struct {
    Name string `json:"employee_name"`
    Age  int    `json:"-"`
}

func main() {
    foo := Foo{Name: "Sam", Age: 20}
    bar := (*Bar)(unsafe.Pointer(&foo))

    jsonBytes, err := json.Marshal(bar)
    if err != nil {
        fmt.Println(err)
        return
    }

    fmt.Println(string(jsonBytes))
}

Ce code sérialise avec succès les données de la structure Foo à l'aide des balises JSON définies dans la structure Bar. Il produit la sortie JSON suivante :

{"employee_name":"Sam"}

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn