이 장에서는 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는 다음과 같습니다.
/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 중국어 웹사이트의 기타 관련 기사를 참조하세요!