ミドルウェア(基本)

こんにちは、Philippです。
私のプラットフォームGo Web Examples Coursesがリリースされたことをお知らせします。GoでのWeb開発に関するわかりやすいビデオコースをお楽しみください。早期賛同者への特別なオファーもぜひご覧ください。
そちらでお会いしましょう! :)
詳細はこちら

ミドルウェア(基本)

この例では、Goで基本的なロギングミドルウェアを作成する方法を示します。

ミドルウェアは、単にhttp.HandlerFuncをパラメーターの1つとして取り、それをラップし、サーバーが呼び出す新しいhttp.HandlerFuncを返します。

// basic-middleware.go
package main

import (
    "fmt"
    "log"
    "net/http"
)

func logging(f http.HandlerFunc) http.HandlerFunc {
    return func(w http.ResponseWriter, r *http.Request) {
        log.Println(r.URL.Path)
        f(w, r)
    }
}

func foo(w http.ResponseWriter, r *http.Request) {
    fmt.Fprintln(w, "foo")
}

func bar(w http.ResponseWriter, r *http.Request) {
    fmt.Fprintln(w, "bar")
}

func main() {
    http.HandleFunc("/foo", logging(foo))
    http.HandleFunc("/bar", logging(bar))

    http.ListenAndServe(":8080", nil)
}
$ go run basic-middleware.go
2017/02/10 23:59:34 /foo
2017/02/10 23:59:35 /bar
2017/02/10 23:59:36 /foo?bar

$ curl -s http://localhost:8080/foo
$ curl -s http://localhost:8080/bar
$ curl -s http://localhost:8080/foo?bar