"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Go의 웹 서비스 API 서버

Go의 웹 서비스 API 서버

2024-07-31에 게시됨
검색:917

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 엔드포인트는 모든 기존 샘플 데이터(배열)를 반환합니다.
/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)
}

프로그램을 실행하면 이제 웹 서버가 활성화되고 데이터를 사용할 수 있습니다.

릴리스 선언문 이 글은 https://dev.to/sukmarizki04/web-service-api-server-in-go-efl?1 에서 복제하였습니다. 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제해 주시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3