Mengendalikan Permintaan CORS Prapenerbangan dalam Go
Dalam membangunkan permintaan HTTP merentas tapak, anda mungkin menghadapi permintaan OPTIONS prapenerbangan untuk menyemak keselamatan permintaan tersebut. Menangani permintaan ini dengan sewajarnya adalah penting dalam konteks Go.
Satu pendekatan asas ialah menyemak kaedah permintaan dalam fungsi pengendali:
func AddResourceHandler(rw http.ResponseWriter, r *http.Request) { switch r.Method { case "OPTIONS": // handle preflight case "PUT": // respond to actual request } }
Pilihan lain ialah menggunakan pakej mux Gorilla, mendaftarkan pengendali "OPTIONS" pra-penerbangan untuk laluan URL yang berkaitan:
r := mux.NewRouter() r.HandleFunc("/someresource/item", AddResourceHandler).Methods("PUT") r.HandleFunc("/someresource/item", PreflightAddResourceHandler).Methods("OPTIONS")
Namun, untuk yang lebih elegan pendekatan, pertimbangkan untuk membalut pengendali REST anda:
func corsHandler(h http.Handler) http.HandlerFunc { return func(w http.ResponseWriter, r *http.Request) { if (r.Method == "OPTIONS") { //handle preflight in here } else { h.ServeHTTP(w,r) } } }
Anda kemudian boleh membalut pengendali seperti ini:
http.Handle("/endpoint/", corsHandler(restHandler))
Dengan memisahkan logik anda dan menggunakan semula pengendali CORS, anda menyelaraskan kod anda dan tingkatkan kebolehselenggaraannya.
Atas ialah kandungan terperinci Bagaimana Mengendalikan Permintaan CORS Prapenerbangan dengan Cekap dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!