」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > Go 中的 Web 服務 Api 伺服器

Go 中的 Web 服務 Api 伺服器

發佈於2024-07-31
瀏覽:501

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)
}

運行程序,現在Web伺服器已上線並且可以使用資料。

版本聲明 本文轉載於:https://dev.to/sukmarizki04/web-service-api-server-in-go-efl?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3