이 장에서는 API 형식의 응답 데이터 유형을 사용하여 API 웹 서비스를 생성하기 위한 go 및 Json 웹 프로그래밍을 소개합니다.
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) }
프로그램을 실행하면 이제 웹 서버가 활성화되고 데이터를 사용할 수 있습니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3