在本章中,我們將介紹 go 和 Json Web 編程,以 API 形式建立具有回應資料類型的 API Web 服務。
package main import "encoding/json" import "net/http" import "fmt" type student struct { ID string Name string Grade int } var data = []student{ student{"E001", "ethan", 21}, student{"W001", "wick", 22}, student{"B001", "bourne", 23}, student{"B002", "bond", 23}, }
上面的student結構體作為樣本資料切片元素類型,儲存在data變數中。
接下來,建立一個 user() 函數來處理 /users 端點。在此函數中,透過 r.Method() 屬性進行請求類型偵測過程,以找出請求類型是 Post 還是 Get 還是其他類型。
func users(w http.ResponseWriter, r *http.Request) { w.Header().Set("Content-Type", "application/json") if r.Method == "GET" { var result, err = json.Marshal(data) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } w.Write(result) return } http.Error(w, "", http.StatusBadRequest) }
如果請求是GET(檢索資料),則資料以JSON編碼
用作響應。
w.Header().Set("Content-Type", "application/json") 語句用於
確定回應類型,即 JSON。而 r.Write()
用於註冊資料作為回應。
否則,如果請求無效,則使用
將回應設為錯誤
http.Error() 函數。
也為 /user 端點設定一個處理程序。該端點與
的區別
上面的 /user 是:
/users 端點傳回所有現有範例資料(陣列)。
/user 端點僅傳回一筆數據,取自 data
基於其 ID 的樣本。在此端點,客戶端必鬚髮送
還有正在尋找的資料的ID資訊
func user(w http.ResponseWriter, r *http.Request) { w.Header().Set("Content-Type", "application/json") if r.Method == "GET" { var id = r.FormValue("id") var result []byte var err error for _, each := range data { if each.ID == id { result, err = json.Marshal(each) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } w.Write(result) return } } http.Error(w, "User not found", http.StatusNotFound) return } http.Error(w, "", http.StatusBadRequest) }
r.FormValue()方法用於檢索從
發送的表單數據
客戶端,在此上下文中引用的資料是 ID。
透過使用該ID,可以搜尋相關數據。如果有的話
作為響應返回。如果不存在,則錯誤 400,錯誤請求
返回訊息“未找到用戶”。
最後,實作上面的兩個處理程序。
func main() { http.HandleFunc("/users", users) http.HandleFunc("/user", user) fmt.Println("starting web server at http://localhost:8080/") http.ListenAndServe(":8080", nil) }
運行程序,現在Web伺服器已上線並且可以使用資料。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3