golang

Go gin middleware 적용하기

개발하는 장군감 2022. 11. 14. 23:26

middleware(미들웨어) ??

client <-> server 통신에서, 중복되는 일(인증, 로깅, ...)을 효과적으로 처리하기 위해 middleware를 활용합니다.
cleint <--> middleware <--> server

middleware(미들웨어)를 golang의 API Server 에서 적용시키는 예제를 확인합니다.

예제

지난 포스트 에서 gin 패키지를 이용한 API 를 만들었었는데 비슷하게 활용할 예정이다.

main.go

package main

import "github.com/gin-gonic/gin"

// middleware 구현
func DummyMiddleware() gin.HandlerFunc {
  // Do some initialization logic here
    return func(c *gin.Context) {
        fmt.Println("This is dummy middleware")
        c.Next()
    }
}

// API handler 구현
func requestPing(c *gin.Context) {
    fmt.Println("got ping")
    c.JSON(200, gin.H{
        "message": "pong",
    })
}

func main() {
  // router 초기화
  r := gin.Default()  
  // middleware 설정
  r.Use(DummyMiddleware())
  // handler 설정
  r.GET("/ping", requestPing)  
  // apiserver 실행
  r.Run() // listen and serve on 0.0.0.0:8080 (for windows "localhost:8080")  
}

결과

API CALL

ping API 호출시 기존과 동일하게 pong message 를 확인할 수 있다.

$ curl localhost:8080/ping
{"message":"pong"}%
$ curl localhost:8080/ping
{"message":"pong"}%

server log

아래와 같이 middleware를 통해 API 호출마다 This is dummy middleware 가 프린트 되고있다.

그 외

미들웨어 함수도 일반함수와 동일하게 returning func 를 통해 initialize logic을 수행할 수 있다. 즉, API server 가 실행되며 middleware func 단위로 초기화 로직이 필요한 경우에 위 예제 코드에서 Do some initialization logic here 주석이 있는 곳에 작성하면 된다.
만약 fmt.Println("dummy middleware initialized") 를 작성하면, API server 가 호출될 때 한번만 프린트 된다.

반응형