Golang HTTP 핸들러 Siesta 라이브러리 알아보기
오늘은 Golang으로 Service 타입의 HTTP 핸들러 Siesta 라이브러리를 알아보려 합니다.
Siesta 설치
우선 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으로 Siesta 패키지를 설치합니다.
go get github.com/VividCortex/siesta
홈의 go 폴더에 Siesta 소스코드와 패키지 파일이 생성됩니다.
예제
package main
해당 소스코드를 실행 파일로 인식하게 해주도록 main이라고 선언합니다.
import (
"fmt"
"log"
"net/http"
"time"
"github.com/VividCortex/siesta"
)
fmt, log, net, time 그리고 siesta를 가져옵니다.
func main() {
service := siesta.NewService("/")
서비스 객체를 생성합니다.
get := "GET"
service.Route(get, "/", "'Hello, world!'",
func(w http.ResponseWriter, r *http.Request) {
fmt.Fprintln(w, "Hello, world!")
})
서비스로 새로운 라우터를 추가하고 Hello, world!를 출력합니다.
timeHandler := func(c siesta.Context, w http.ResponseWriter, r *http.Request) {
timeDelta := time.Now().Sub(c.Get("time").(time.Time))
fmt.Fprintf(w, "%v", timeDelta)
}
contextHandler에서 저장되는 특정 값을 불러와서 출력하는 핸들러를 구현합니다.
contextHandler := siesta.Compose(func(c siesta.Context, w http.ResponseWriter, r *http.Request) {
c.Set("time", time.Now())
}, timeHandler)
이미 구현한 핸들러 함수와 값을 저장하는 핸들러 함수를 단일 contextHandler 함수로 구성합니다.
service.Route("GET", "/time", "usage", contextHandler)
만든 contextHandler를 서비스로 새로운 라우터에 추가합니다.
err := http.ListenAndServe(":8080", service)
if err != nil {
log.Fatal(err)
}
}
8080 포트로 서버를 구동합니다.
Written on December 17, 2019