recherche
Maisondéveloppement back-endGolangComment j'écris des API Go dans mon expérience avec Fuego

How I write Go APIs in  my experience with Fuego

Mon expérience dans la création d'API Go avec Fuego

En tant que développeur Go avec plusieurs années d'expérience, j'ai exploré différents frameworks web. Mon parcours comprenait la bibliothèque standard, Gin et Fiber. Bien que chacun ait ses mérites, j'ai souvent eu besoin de plus de structure ou j'ai passé trop de temps à intégrer plusieurs bibliothèques à des fins de validation, de sérialisation et de documentation. C'est là que Fuego a changé la donne.

Au départ, Fuego semblait être juste un autre framework. Cependant, son utilisation des fonctionnalités Go modernes, notamment génériques, pour générer automatiquement des spécifications OpenAPI directement à partir du code, m'a intrigué. J'ai décidé de le tester sur un petit projet interne, et voici mon compte honnête.


Premières impressions

La simplicité de Fuego était immédiatement apparente. La configuration d'un serveur de base n'a pris que quelques minutes :

package main

import "github.com/go-fuego/fuego"

func main() {
    s := fuego.NewServer()
    fuego.Get(s, "/", func(c fuego.ContextNoBody) (string, error) {
        return "Hello, World!", nil
    })
    s.Run()
}

La familiarité était frappante : similaire à Gin, mais avec le support OpenAPI intégré.


Un exemple concret

L'exemple « Hello World » ne reflète pas les complexités du monde réel. Mon application nécessitait une gestion des données JSON, une validation et des réponses saisies. D'autres frameworks nécessitent un décodage JSON personnalisé, une gestion des erreurs et une intégration de middleware. Fuego a considérablement rationalisé cela en utilisant des gestionnaires de routes typés.

Voici un gestionnaire d'itinéraire simplifié :

type UserInput struct {
    Name string `json:"name" validate:"required"`
}

type UserOutput struct {
    Message string `json:"message"`
}

func main() {
    s := fuego.NewServer()
    fuego.Post(s, "/user", handleUser)
    s.Run()
}

func handleUser(c fuego.ContextWithBody[UserInput]) (UserOutput, error) {
    in, err := c.Body()
    if err != nil {
        return UserOutput{}, err
    }
    return UserOutput{Message: "Hello, " + in.Name}, nil
}

Améliorations clés :

  1. Gestionnaires typés : fuego.ContextWithBody[UserInput] désérialise automatiquement JSON dans la structure UserInput.
  2. Validation : validate:"required" garantit que le champ Name est présent ; Fuego gère les erreurs avec élégance.
  3. Réponses : Le renvoi d'une structure UserOutput la sérialise automatiquement en JSON.

Cela a éliminé un code passe-partout important : pas de json.Unmarshal, de bibliothèques de validation externes ou de gestion des erreurs personnalisée.


Pourquoi Fuego se démarque

  1. Native Go Feel : Contrairement aux frameworks qui enveloppent fortement net/http, Fuego se sent remarquablement natif. Il utilise net/http directement, permettant une intégration transparente des middleware et des gestionnaires standard. J'ai réutilisé le middleware d'authentification existant sans problème.

  2. Génération automatique d'OpenAPI : Auparavant, je gérais des fichiers YAML séparés ou je m'appuyais sur les commentaires pour les spécifications OpenAPI, un processus fastidieux et sujet aux erreurs. Fuego génère automatiquement les spécifications à partir des types de gestionnaires de routes, garantissant que la documentation reste toujours à jour.

  3. Validation et gestion des erreurs : La validation intégrée (à l'aide de go-playground/validator) était intuitive et la gestion des erreurs a été simplifiée. Les structures UserInput invalides ont entraîné des messages d'erreur structurés conformes aux normes RFC.


Transformations de données

Pour m'assurer que tous les champs Name entrants étaient en minuscules, j'ai utilisé la méthode InTransform de Fuego :

package main

import "github.com/go-fuego/fuego"

func main() {
    s := fuego.NewServer()
    fuego.Get(s, "/", func(c fuego.ContextNoBody) (string, error) {
        return "Hello, World!", nil
    })
    s.Run()
}

Cela transforme automatiquement les données avant d'atteindre le gestionnaire d'itinéraire.


Défis rencontrés

  1. Écosystème plus petit : La base d'utilisateurs plus petite de Fuego par rapport à Gin ou Echo a entraîné moins de ressources communautaires facilement disponibles. Cependant, les exemples et la documentation du référentiel se sont avérés suffisants.

  2. Middleware intégré limité : Bien que Fuego fournisse un certain middleware, il n'est pas aussi complet que certains frameworks plus anciens. net/http compatibilité autorisée à l'aide de bibliothèques externes ou d'un middleware personnalisé.


Conclusion

Fuego offre un équilibre convaincant entre commodité et flexibilité. Il accélère le développement d'API grâce à la validation, la sérialisation et la génération de documentation intégrées, tout en restant fidèle aux principes de Go. Utiliser des structures typées et laisser Fuego gérer le reste a considérablement amélioré mon flux de travail.

Principaux avantages :

  • Productivité accrue : Code plus propre et passe-partout réduit.
  • Documentation automatisée : Spécifications OpenAPI toujours à jour.
  • Transitions fluides : Intégration facile avec les net/http gestionnaires existants.

Si vous recherchez un framework Go moderne et flexible, surtout si vous en avez assez de la maintenance manuelle OpenAPI, je recommande fortement Fuego. Cela a simplifié mon processus de développement tout en restant fidèle à la philosophie minimaliste de Go. Le référentiel GitHub fournit des informations complètes et une feuille de route prometteuse. Je suis enthousiasmé par son avenir et je continuerai à l'utiliser pour de futurs projets.

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
Comment utiliser le package 'Strings' pour manipuler les chaînes dans GO étape par étapeComment utiliser le package 'Strings' pour manipuler les chaînes dans GO étape par étapeMay 13, 2025 am 12:12 AM

Le package des chaînes de Go fournit une variété de fonctions de manipulation de chaînes. 1) Utilisez des chaînes. Continent pour vérifier les sous-chaînes. 2) Utilisez des chaînes.split pour diviser la chaîne en tranches de sous-chaîne. 3) Fusionner les cordes à travers les cordes.join. 4) Utilisez des chaînes.trimspace ou des chaînes.trim pour supprimer des blancs ou des caractères spécifiés au début et à la fin d'une chaîne. 5) Remplacez toutes les sous-chaînes spécifiées par des chaînes. 6) Utilisez Strings.hasprefix ou Strings.hassuffix pour vérifier le préfixe ou le suffixe de la chaîne.

Package GO Strings: Comment améliorer mon code?Package GO Strings: Comment améliorer mon code?May 13, 2025 am 12:10 AM

L'utilisation du package GO Language Strings peut améliorer la qualité du code. 1) Utilisez des chaînes.join () pour connecter élégamment les réseaux de chaînes pour éviter les frais généraux de performances. 2) Combinez des chaînes.split () et des chaînes.Contes () pour traiter le texte et faire attention aux problèmes de sensibilité aux cas. 3) Évitez l'abus de cordes.replace () et envisagez d'utiliser des expressions régulières pour un grand nombre de substitutions. 4) Utilisez des chaînes.

Quelles sont les fonctions les plus utiles dans le package GO BYTES?Quelles sont les fonctions les plus utiles dans le package GO BYTES?May 13, 2025 am 12:09 AM

Le package des octets de Go offre une variété de fonctions pratiques pour gérer le tranchage des octets. 1.Bytes.Contains est utilisé pour vérifier si la tranche d'octets contient une séquence spécifique. 2.Bytes.Split est utilisé pour diviser les tranches d'octets en petits pièces. 3. bytes.join est utilisé pour concaténer plusieurs tranches d'octets en une seule. 4.Bytes.trimspace est utilisé pour retirer les blancs avant et arrière des tranches d'octets. 5.Bytes.Equal est utilisé pour comparer si deux tranches d'octets sont égales. 6.Bytes.Index est utilisé pour trouver l'indice de départ des sous-lisses dans les lieux de grande envergure.

Maîtriser la gestion des données binaires avec le package 'Encoding / Binary' de Go: un guide completMaîtriser la gestion des données binaires avec le package 'Encoding / Binary' de Go: un guide completMay 13, 2025 am 12:07 AM

Theencoding / binarypackageingoissentialBecauseitprovidesastandardwaytoreadandwriteBinaryData, assurant la plateforme de la compatibilité et la maintenance de la Différendianité.

Allez 'octets' référence rapideAllez 'octets' référence rapideMay 13, 2025 am 12:03 AM

TheyTespackageingOiscrucialforHandlingByteslices et Buffers, offrant destiné à dire de manière importante de la gestion et de la datamanipulation.1)

Mastering go Strings: une plongée profonde dans le paquet 'Strings'Mastering go Strings: une plongée profonde dans le paquet 'Strings'May 12, 2025 am 12:05 AM

Vous devez vous soucier du package "Strings" dans GO, car il fournit des outils pour gérer les données de texte, l'épissage des chaînes de base à la correspondance avancée de l'expression régulière. 1) Le package "Strings" fournit des opérations de chaîne efficaces, telles que les fonctions de jointure utilisées pour épisser les chaînes pour éviter les problèmes de performances. 2) Il contient des fonctions avancées, telles que la fonction CONTAINSAL, pour vérifier si une chaîne contient un jeu de caractères spécifique. 3) La fonction de remplacement est utilisée pour remplacer les sous-chaînes d'une chaîne, et l'attention doit être accordée à l'ordre de remplacement et à la sensibilité à la casse. 4) La fonction divisée peut diviser les chaînes en fonction du séparateur et est souvent utilisée pour le traitement de l'expression régulière. 5) Les performances doivent être prises en compte lors de l'utilisation, comme

Package 'Encoding / Binary' dans Go: votre go-to pour les opérations binairesPackage 'Encoding / Binary' dans Go: votre go-to pour les opérations binairesMay 12, 2025 am 12:03 AM

Le "codage / binaire" PackageingOssentialForHandlingBinaryData, offrantoolsforreadingandwritingBinaryDataefficiently.1) itsupportsbothlittle-EndianandBig-EndianByteorders, Crucialforcross-System Compatibilité.2) ThepackageAlworkingwithcus

Tutoriel de manipulation de la tranche d'octets: maîtrise le package 'octets'Tutoriel de manipulation de la tranche d'octets: maîtrise le package 'octets'May 12, 2025 am 12:02 AM

La maîtrise du package d'octets dans GO peut aider à améliorer l'efficacité et l'élégance de votre code. 1) Le package des octets est crucial pour l'analyse des données binaires, le traitement des protocoles de réseau et la gestion de la mémoire. 2) Utilisez des bytes.buffer pour construire progressivement les tranches d'octets. 3) Le package d'octets fournit les fonctions de recherche, de remplacement et de segmentation des tranches d'octets. 4) Le type de lecteur d'octets convient pour la lecture des données des tranches d'octets, en particulier dans les opérations d'E / S. 5) Le package des octets fonctionne en collaboration avec GO'S GARBAGE Collector, améliorant l'efficacité du traitement des mégadonnées.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

<🎜>: Bubble Gum Simulator Infinity - Comment obtenir et utiliser les clés royales
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Comment déverrouiller le grappin
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
Nordhold: Système de fusion, expliqué
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

PhpStorm version Mac

PhpStorm version Mac

Le dernier (2018.2.1) outil de développement intégré PHP professionnel

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux

Version Mac de WebStorm

Version Mac de WebStorm

Outils de développement JavaScript utiles

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Puissant environnement de développement intégré PHP