Gestion des requêtes de contrôle en amont CORS avec Go
Dans un serveur backend RESTful écrit en Go, la gestion des requêtes HTTP d'origine croisée nécessite de traiter les requêtes CORS de contrôle en amont . Voici comment y faire face efficacement :
1. Vérification manuelle de la méthode :
Dans net/http, la méthode de requête peut être vérifiée dans la fonction de gestionnaire. Par exemple :
func AddResourceHandler(rw http.ResponseWriter, r *http.Request) { switch r.Method { case "OPTIONS": // Preflight handling logic case "PUT": // Actual request response } }
2. Package Gorilla Mux :
Gorilla Mux permet d'enregistrer un gestionnaire de contrôle en amont distinct pour chaque chemin d'URL. Par exemple :
r := mux.NewRouter() r.HandleFunc("/someresource/item", AddResourceHandler).Methods("PUT") r.HandleFunc("/someresource/item", PreflightAddResourceHandler).Methods("OPTIONS")
3. HTTP Handler Wrapper :
Pour découpler la logique et réutiliser le gestionnaire CORS, envisagez d'encapsuler le gestionnaire REST. Par exemple, dans net/http:
func corsHandler(h http.Handler) http.HandlerFunc { return func(w http.ResponseWriter, r *http.Request) { if r.Method == "OPTIONS" { // Preflight handling } else { h.ServeHTTP(w, r) } } }
Usage:
http.Handle("/endpoint/", corsHandler(restHandler))
Ces approches fournissent des solutions élégantes pour gérer les demandes de contrôle en amont CORS dans Go. Choisissez celui qui correspond le mieux à l'architecture de votre application.
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!