1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Go Web Examplesの和訳 Routing (using gorilla/mux)

Last updated at Posted at 2018-09-06

Go勉強会 Webアプリケーション編 #1で使おうと思っているGo Web Examplesの和訳です。ほぼGoogle翻訳ですが、リンク等も整理された状態であると便利だと思い作りました。前回(HTTP Server)次回: Go Web Examplesの和訳 (Templates)

はじめに

Goのnet/httpパッケージは、HTTPプロトコルに多くの機能を提供します。それがうまく行かないことの1つは、リクエストURLを単一のパラメータに分割するような複雑なリクエストルーティングです。幸運なことに、これには非常に一般的なパッケージがあります。これは、Goコミュニティの優れたコード品質でよく知られています。この例では、gorilla/muxパッケージを使用して、名前付きパラメータ、GET/POSTハンドラ、およびドメイン制限を使用してルートを作成する方法を示します。

gorilla/muxパッケージのインストール

gorilla/muxは、GoのデフォルトのHTTPルーターに適合するパッケージです。 Webアプリケーションを書くときに生産性を向上させるための多くの機能が付属しています。また、Goのデフォルトのリクエストハンドラシグネチャfunc(w http.ResponseWriter、r * http.Request)にも準拠しているため、ミドルウェアや既存のアプリケーションなどの他のHTTPライブラリとパッケージを混在させることができます。 GitHubからパッケージをインストールするには、go getコマンドを使用します(-uオプションは常に最新のバージョンをネットワークから取得します。)

go get -u github.com/gorilla/mux

新しいルーターの作成

最初に新しいリクエストルータを作成します。ルータはWebアプリケーションのメインルータであり、後でパラメータとしてサーバに渡されます。すべてのHTTP接続を受け取り、それを登録するリクエストハンドラに渡します。次のように新しいルータを作成することができます。

r := mux.NewRouter()

リクエストハンドラの登録

新しいルータを取得したら、いつものようにリクエストハンドラを登録できます。唯一の違いは、http.HandleFunc(...)を呼び出す代わりに、ルータでHandleFuncを以下のように呼び出すことです:r.HandleFunc(...)

URLパラメータ

gorilla/muxのルーターの最大の強みはリクエストURLからのセグメントの抽出です。
例えば、これはアプリケーションのURLです。

/books/go-programming-blueprint/page/10

このURLには2つの動的なセグメントがあります。

  1. 書籍タイトルのスラッグ(go-programming-blueprint)
  2. ページ番号(10)

リクエストハンドラを上記のURLに一致させるために、動的セグメントをURLパターンのプレースホルダに置き換えると、次のようになります。

r.HandleFunc("/books/{title}/page/{page}", func(w http.ResponseWriter, r *http.Request) {
	// get the book
	// navigate to the page
})

最後に、これらのセグメントからデータを取得します。パッケージには、パラメータhttp.Requestを引数とし、セグメントのマップを返す関数mux.Vars(r)が付属しています。

func(w http.ResponseWriter, r *http.Request) {
	vars := mux.Vars(r)
	vars["title"] // the book title slug
	vars["page"] // the page
}

HTTPサーバーのルーターの設定

http.ListenAndServe(":80",nil)で何がnilなのか疑問に思ったことはありませんか? これは、HTTPサーバーのメインルーターのパラメーターです。 デフォルトではnilです。つまり、net/httpパッケージのデフォルトルータ(DefaultServeMux)を使用することを意味します。 独自のルータを使用するには、nilをルータの変数rで置き換えます。

http.ListenAndServe(":80", r)

コード(コピペ用)

これは、この例で学んだことを試すために使用できる完全なコードです。

package main

import (
	"fmt"
	"net/http"

	"github.com/gorilla/mux"
)

func main() {
	r := mux.NewRouter()
	r.HandleFunc("/books/{title}/page/{page}", func(w http.ResponseWriter, r *http.Request) {
		vars := mux.Vars(r)
		title := vars["title"]
		page := vars["page"]

		fmt.Fprintf(w, "You've requested the book: %s on page %s\n", title, page)
	})

	http.ListenAndServe(":80", r)
}

gorilla/muxルーターの機能

メソッド

リクエストハンドラを特定のHTTPメソッドに制限する。

r.HandleFunc("/books/{title}", CreateBook).Methods("POST")
r.HandleFunc("/books/{title}", ReadBook).Methods("GET")
r.HandleFunc("/books/{title}", UpdateBook).Methods("PUT")
r.HandleFunc("/books/{title}", DeleteBook).Methods("DELETE")

Hostnames & Subdomains

リクエストハンドラを特定のホスト名またはサブドメインに制限する。

r.HandleFunc("/books/{title}", BookHandler).Host("www.mybookstore.com")

Schemes

リクエストハンドラをhttp/httpsに制限します。

r.HandleFunc("/secure", SecureHandler).Schemes("https")
r.HandleFunc("/insecure", InsecureHandler).Schemes("http")

Path Prefixes & Subrouters

リクエストハンドラを特定のパスプリフィックスに制限する。

bookrouter := r.PathPrefix("/books").Subrouter()
bookrouter.HandleFunc("/", AllBooks)
bookrouter.HandleFunc("/{title}", GetBook)

参考

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?