首頁 >後端開發 >Golang >Go 中的 Web 服務 Api 伺服器

Go 中的 Web 服務 Api 伺服器

PHPz
PHPz原創
2024-07-23 13:36:311181瀏覽

Web Service Api Server in Go

在本章中,我們將介紹 go 和 Json Web 編程,以 API 形式建立具有回應資料類型的 API Web 服務。

  1. WEB 建立 API 首先準備一些樣本數據
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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn