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
Libérer: 2024-12-17 03:25:25
original
419 Les gens l'ont consulté

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"`
}
Copier après la connexion

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:"-"`
}
Copier après la connexion

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))
Copier après la connexion

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))
}
Copier après la connexion

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"}
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal