在本章中,我們將介紹 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) }
運行程序,現在網路伺服器已上線,可以使用資料了。
以上是Go 中的 Web 服務 Api 伺服器的詳細內容。更多資訊請關注PHP中文網其他相關文章!