コンテンツにスキップ

バインディング

リクエストデータの解析は、Web アプリケーションの重要な要素です。Echo ではこれを バインディング と呼び、HTTP リクエストの 4 つの部分から読み取れます。

  • URL パスパラメーター
  • URL クエリパラメーター
  • Header
  • リクエストボディ

Struct タグによるバインディング

Section titled “Struct タグによるバインディング”

データソースとキーを指定するタグ付きの struct を定義し、そのポインターを c.Bind() に渡します。ここではクエリパラメーター idID フィールドに バインドされます。

type User struct {
ID string `query:"id"`
}
// handler for /users?id=<userID>
var user User
if err := c.Bind(&user); err != nil {
return c.String(http.StatusBadRequest, "bad request")
}
タグソース
queryクエリパラメーター
paramパスパラメーター
headerHeader 値
formフォームデータ(クエリ + ボディ)
jsonリクエストボディ(encoding/json
xmlリクエストボディ(encoding/xml

パス、クエリ、header、フォームのフィールドには明示的なタグが必要です。 JSON と XML はタグが省略された場合、標準ライブラリと同じように struct フィールド名へ フォールバックします。

リクエストボディをデコードするときは、Content-Type header によってデコーダーが選ばれます。

  • application/json
  • application/xml
  • application/x-www-form-urlencoded

1 つのフィールドで複数のソースを宣言できます。データは次の順序でバインドされ、 各ステップが前の値を上書きします。

  1. パスパラメーター
  2. クエリパラメーター(GET / DELETE のみ)
  3. リクエストボディ
type User struct {
ID string `param:"id" query:"id" form:"id" json:"id" xml:"id"`
}

1 つのソースから直接バインドする

Section titled “1 つのソースから直接バインドする”
echo.BindBody(c, &payload) // request body
echo.BindQueryParams(c, &payload) // query parameters
echo.BindPathValues(c, &payload) // path parameters
echo.BindHeaders(c, &payload) // headers
type UserDTO struct {
Name string `json:"name" form:"name" query:"name"`
Email string `json:"email" form:"email" query:"email"`
}
e.POST("/users", func(c *echo.Context) error {
var dto UserDTO
if err := c.Bind(&dto); err != nil {
return c.String(http.StatusBadRequest, "bad request")
}
user := User{Name: dto.Name, Email: dto.Email, IsAdmin: false}
executeSomeBusinessLogic(user)
return c.JSON(http.StatusOK, user)
})

単一ソースから明示的かつ型安全にバインドするには、フルーエント binder を使います。 設定をチェーンし、実行時にエラーを収集します。

// /api/search?active=true&id=1&id=2&id=3&length=25
var opts struct {
IDs []int64
Active bool
}
length := int64(50)
err := echo.QueryParamsBinder(c).
Int64("length", &length).
Int64s("id", &opts.IDs).
Bool("active", &opts.Active).
BindError() // first error, if any

利用できる binder は echo.QueryParamsBinder(c)echo.PathValuesBinder(c)echo.FormFieldBinder(c) です。チェーンは BindError()(最初のエラー)または BindErrors()(すべてのエラー)で終了します。FailFast(false) はチェーン全体を実行します。 デフォルトでは早期終了が有効です。

各サポート型には Type(...)MustType(...)Types(...)(スライス)、 MustTypes(...) メソッドがあります。例:Int64MustInt64Int64s。 カンマ区切りの値を分割するには BindWithDelimiter("id", &dest, ",") を使います。

Echo#Binder でカスタム binder を登録します。

type CustomBinder struct{}
func (cb *CustomBinder) Bind(c *echo.Context, i any) error {
db := new(echo.DefaultBinder)
if err := db.Bind(c, i); err != echo.ErrUnsupportedMediaType {
return err
}
// custom logic here
return nil
}
e.Binder = &CustomBinder{}