Formatage des horodatages dans un JSON sortant avec Time.Time
En Go, lors de l'envoi d'un type time.Time dans le cadre d'une réponse JSON, il est souvent souhaitable de formater l'horodatage dans le format souhaité au lieu du format ISO 8601 par défaut. Pour y parvenir, vous pouvez utiliser les techniques suivantes :
Marshaling et Unmarshaling personnalisés
L'interface Marshall peut être implémentée par des types personnalisés pour déterminer leur représentation JSON. De même, l'interface Unmarshaler peut être utilisée pour contrôler l'analyse des données JSON en types personnalisés. Pour time.Time, nous allons définir un type JSONTime qui implémente MarshalJSON :
type JSONTime time.Time func (t JSONTime) MarshalJSON() ([]byte, error) { // Format the time in the desired format stamp := fmt.Sprintf("\"%s\"", time.Time(t).Format("Mon Jan _2")) return []byte(stamp), nil }
Mise à jour du type de document
Dans le type de document, modifiez le champ Stamp tapez JSONTime :
type Document struct { ... Stamp JSONTime ... }
Exemple Utilisation
Maintenant, lors de l'initialisation du document de test :
testDoc := model.Document{ ... Stamp: JSONTime(time.Now()), ... }
L'horodatage sera formaté selon le format spécifié lorsqu'il est codé en JSON :
{ ... "Stamp": "May 15, 2014" ... }
Cette approche offre flexibilité et contrôle sur la façon dont les horodatages sont formatés dans les réponses JSON, permettant une personnalisation en fonction d'exigences spécifiques.
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!