>백엔드 개발 >Golang >Go의 웹 서비스 API 서버

Go의 웹 서비스 API 서버

PHPz
PHPz원래의
2024-07-23 13:36:311232검색

Web Service Api Server in Go

이 장에서는 API 형식의 응답 데이터 유형을 사용하여 API 웹 서비스를 생성하기 위한 go 및 Json 웹 프로그래밍을 소개합니다.

  1. 웹 생성 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},
}

위의 학생 구조체는 데이터 변수에 저장된 샘플 데이터 조각 요소 유형으로 사용됩니다.
다음으로 /users 엔드포인트를 처리하는 user() 함수를 만듭니다. 이 함수에는 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 엔드포인트에 대한 핸들러를 설정하십시오. 이 끝점과
의 차이점 위의 /users는 다음과 같습니다.
/users 엔드포인트는 기존의 모든 샘플 데이터(배열)를 반환합니다.
/user 엔드포인트는 데이터에서 가져온 단 하나의 데이터만 반환합니다
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의 웹 서비스 API 서버의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.