Golang RESTful JSON API Go-Json-Rest 라이브러리 알아보기 1
오늘은 Golang으로 RESTful JSON API를 만들 수 있는 Go-Json-Rest 라이브러리를 알아보려 합니다.
Go-Json-Rest 설치
우선 Golang의 환경을 구성하기 위해 https://golang.org/dl/ 에서 윈도우, 리눅스, 맥에서 설치 프로그램을 내려받을 수 있습니다.
맥에서 brew로 쉽게 설치할 수 있습니다.
brew install go
우분투에서도 apt로 쉽게 설치할 수 있습니다.
sudo apt-get install golang-go
맥에서 Golang의 버전을 올리려면 brew를 이용합니다.
brew upgrade go
우분투에서도 Golang의 버전을 올리려면 backports 저장소를 등록하고 apt를 이용합니다.
sudo add-apt-repository ppa:longsleep/golang-backports
sudo apt-get update
sudo apt-get install golang-go
go get으로 Go-Json-Rest 패키지를 설치합니다.
go get github.com/ant0ine/go-json-rest/rest
홈의 go 폴더에 Go-Json-Rest 소스코드와 패키지 파일이 생성됩니다.
예제
package main
해당 소스코드를 실행 파일로 인식하게 해주도록 main이라고 선언합니다.
import (
"log"
"net/http"
"github.com/ant0ine/go-json-rest/rest"
)
log, net 그리고 go-json-rest를 가져옵니다.
func main() {
restAPI := rest.NewApi()
API 객체를 만듭니다.
restAPI.Use(rest.DefaultDevStack...)
개발에 필요한 로그, 타임존, 오류 처리와 같은 미들웨어를 사용합니다.
restAPI.SetApp(rest.AppSimple(func(w rest.ResponseWriter, r *rest.Request) {
w.WriteJson(map[string]string{"Body": "Hello World!"})
}))
AppSimple로 간단하게 Hello World!를 띄울 수 있습니다.
http.Handle("/", http.StripPrefix("/", restAPI.MakeHandler()))
HTTP 요청을 처리하는 핸들러를 반환하여 해당 경로로 접근할 때 미리 만든 API 객체가 수행될 수 있게 합니다.
log.Fatal(http.ListenAndServe(":8080", nil))
}
8080 포트로 restful api 서버를 만듭니다.
다음 포스트에는 라우터를 만들어서 값을 파라미터로 받는 예제를 작성해보려 합니다.
Written on December 1, 2019