Go ist eine großartige Sprache für die Systemprogrammierung, aber sie glänzt auch im Web, insbesondere beim Erstellen von REST-APIs. Dieser Leitfaden führt Sie Schritt für Schritt durch die Erstellung einer einfachen REST-API mithilfe der Standardbibliothek von Go. Wir erstellen eine API zum Verwalten einer Serverliste, sodass wir Serverdatensätze hinzufügen, entfernen und anzeigen können. Wir werden auch die neuen Router-Verbesserungen von Go 1.22 für den Methodenabgleich verwenden, was uns sauberere Routen und Handler ermöglicht.
Diese Anleitung setzt voraus, dass Sie über grundlegende Kenntnisse von Go verfügen und es auf Ihrem Computer installiert ist.
Erstellen Sie ein neues Verzeichnis für Ihr Projekt und initialisieren Sie ein Go-Modul:
mkdir server-api cd server-api go mod init server-api
Erstellen Sie eine Datei mit dem Namen main.go. Wir verwenden das Standard-http-Paket von Go – es enthält alles, was wir für eine grundlegende API benötigen.
package main import ( "encoding/json" "fmt" "log" "net/http" )
Lassen Sie uns zunächst definieren, wie ein Server aussieht. Wir halten es einfach – nur eine ID, einen Namen, eine IP-Adresse und eine Region:
type Server struct { ID string `json:"id"` Name string `json:"name"` IP string `json:"ip"` Region string `json:"region` }
Wir speichern unsere Server mithilfe eines Slice im Speicher. In einer echten Anwendung würden Sie wahrscheinlich eine Datenbank verwenden:
var servers = []Server{ {ID: "srv1", Name: "prod-1", IP: "10.0.1.1", Region: "us-east"}, {ID: "srv2", Name: "prod-2", IP: "10.0.1.2", Region: "eu-west"}, }
Als nächstes richten wir unsere Routen ein. Mit Go 1.22 wurde eine neue Routing-Syntax eingeführt, die dies ziemlich einfach macht:
func main() { mux := http.NewServeMux() mux.HandleFunc("GET /servers", listServers) mux.HandleFunc("GET /servers/{id}", showServer) mux.HandleFunc("POST /servers", createServer) mux.HandleFunc("DELETE /servers/{id}", deleteServer) fmt.Println("Server starting on port 8080...") log.Fatal(http.ListenAndServe(":8080", mux)) }
Jetzt implementieren wir jeden Handler. Zuerst alle Server auflisten:
func listServers(w http.ResponseWriter, r *http.Request) { w.Header().Set("Content-Type", "application/json") json.NewEncoder(w).Encode(servers) }
Einen einzelnen Server anhand der ID abrufen:
func showServer(w http.ResponseWriter, r *http.Request) { w.Header().Set("Content-Type", "application/json") id := r.PathValue("id") for _, server := range servers { if server.ID == id { json.NewEncoder(w).Encode(server) return } } http.Error(w, "Server not found", http.StatusNotFound) }
Neuen Server erstellen:
func createServer(w http.ResponseWriter, r *http.Request) { w.Header().Set("Content-Type", "application/json") var server Server if err := json.NewDecoder(r.Body).Decode(&server); err != nil { http.Error(w, err.Error(), http.StatusBadRequest) return } servers = append(servers, server) w.WriteHeader(http.StatusCreated) json.NewEncoder(w).Encode(server) }
Und schließlich einen Server löschen:
func deleteServer(w http.ResponseWriter, r *http.Request) { id := r.PathValue("id") for i, server := range servers { if server.ID == id { servers = append(servers[:i], servers[i+1:]...) w.WriteHeader(http.StatusNoContent) return } } http.Error(w, "Server not found", http.StatusNotFound) }
Sobald Sie den Code installiert haben, führen Sie ihn aus:
go run main.go
So interagieren Sie mit jedem Endpunkt mithilfe von cURL:
Alle Server auflisten:
curl localhost:8080/servers
Besorgen Sie sich einen bestimmten Server:
curl localhost:8080/servers/srv1
Server hinzufügen:
curl -X POST localhost:8080/servers -H "Content-Type: application/json"; -d '{"id":"srv3","name":"prod-3","ip":"10.0.1.3","region":"ap-south"}';
Einen Server löschen:
curl -X DELETE localhost:8080/servers/srv1
Dies ist eine grundlegende API, aber Sie könnten noch viel hinzufügen:
Die Standardbibliothek ist überraschend gut zum Erstellen von APIs geeignet. Es sind zwar mehr Frameworks mit vollem Funktionsumfang verfügbar, aber wenn Sie mit der Standardbibliothek beginnen, können Sie die Grundlagen besser verstehen, ohne dass hinter den Kulissen irgendwelche Zaubertricks passieren.
Das obige ist der detaillierte Inhalt vonErstellen einer einfachen REST-API mit Go. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!