検索
ホームページバックエンド開発GolangGin-Gonic の Milogo を使用して REST API レスポンスを簡素化する

Simplify Your REST API Responses with Milogo for Gin-Gonic

フィールド選択パターンを実装するGin-Gonicミドルウェア

私の会社では Go を使用して内部ツールを構築しています。最近、gin-gonic を使用して REST API で作業しましたが、これには多くのエンドポイントにわたって大量のデータを表示する必要がありました。

このタイプのシナリオで必須の機能の 1 つは ページネーション ですが、見落とされがちなパターンは 部分応答 (別名フィールド選択) です。これは、Web サーバーの応答に含まれるデータ量をフィルターで除外するための非常に優れた追加機能でもあります。

フィールド選択とは何ですか?

まず、フィールド選択について私が何を意味するのかを明確にしましょう。次のエンドポイントがあると想像してください:

// > GET /api/products
[
  {
    "id": 1,
    "createdAt": "2024-18-11",
    "updatedAt": "2024-18-11",
    "code": "1",
    "price": {
      "amount": 100,
      "currency": "EUR"
    },
    "manufacturedBy": "myshop",
    "stock": 552,
    ...
  },
  ...
]

部分応答を使用すると、クライアントはフィールド クエリ パラメーターで出力をフィルタリングできます (例:
)

// > GET /api/products?fields=code,price
[
  {
    "code": "1",
    "price": {
      "amount": 100,
      "currency": "EUR"
    }
  },
  ...
]
クエリパラメータで宣言されたフィールド

のみが返されます。ペイロード サイズを削減し、帯域幅を節約します。

ミロゴのご紹介

このパターンに利用できる実装が見つからなかったので、自分で作成することにしました。そうして Milogo が誕生しました。
Milogo は、API 応答を処理し、fields クエリ パラメーターで指定されたフィールドをフィルターで除外し、要求されたデータのみを返す Jin ミドルウェアです。

利用可能な主な機能の一部:

  • json オブジェクトと json 配列のサポート。
    したがって、Milogo は、項目の配列または 1 つの項目だけで始まる JSON 応答のフィールドをフィルターできます。

  • ネストされた JSON オブジェクト内のフィールドのフィルタリングのサポート。
    Milogo は、次の形式でネストされた JSON オブジェクトのフィルタリングもサポートしています。コード、価格(金額)

  • 別の json でラップされた json のサポート。
    JSON 応答が別の JSON オブジェクトでラップされる場合があります。Milogo は実際のペイロードのフィルタリングをサポートしています (ラップされた例を参照):

// GET /products?fields=code,price(amount)
{
  "data": [
    {
      "code": 1,
      "price": {
        "amount": 100
      }
    },
    ...
  ],
  "_metadata": {
    ...
  }
}

はじめる

他の gin ミドルウェアと同様に、Milogo は使用とセットアップが非常に簡単です。github リポジトリの README に従うことができますが、基本的には次のとおりです。

r := gin.Default()
r.Use(Milogo())

Milogo ミドルウェアを API に追加するには十分です。

前の例では、Milogo はすべての単一エンドポイントに適用されますが、エンドポイントのグループのみ、または特定のエンドポイントのみに適用することも可能です (例:
)

group := r.Group("/products", milogo.Milogo())
group.GET("", productsHandler)

前の例では、/products グループのみに Milogo のミドルウェアが適用されます。

結論

Milogo は、REST API 開発を簡素化し、クライアントとサーバーの対話を改善するように設計されています。例とドキュメントについては、GitHub リポジトリを確認してください。

お気軽に連絡したり、貢献してください。一緒に REST API を効率的にしましょう!

以上がGin-Gonic の Milogo を使用して REST API レスポンスを簡素化するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか?Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか?Mar 03, 2025 pm 05:17 PM

この記事では、Goのパッケージインポートメカニズム:名前付きインポート(例:インポート "fmt")および空白のインポート(例:_" fmt")について説明しています。 名前付きインポートはパッケージのコンテンツにアクセス可能になり、空白のインポートはtのみを実行します

MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は?MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は?Mar 03, 2025 pm 05:18 PM

この記事では、MySQLクエリの結果をGO structスライスに効率的に変換することを詳しく説明しています。 データベース/SQLのスキャン方法を使用して、手動で解析することを避けて強調しています。 DBタグとロブを使用した構造フィールドマッピングのベストプラクティス

Beegoフレームワークのページ間で短期情報転送を実装する方法は?Beegoフレームワークのページ間で短期情報転送を実装する方法は?Mar 03, 2025 pm 05:22 PM

この記事では、Webアプリケーションでのページ間データ転送のためのBeegoのnewflash()関数について説明します。 newflash()を使用して、コントローラー間で一時的なメッセージ(成功、エラー、警告)を表示し、セッションメカニズムを活用することに焦点を当てています。 リミア

GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか?GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか?Mar 10, 2025 pm 03:20 PM

この記事では、GENICSのGOのカスタムタイプの制約について説明します。 インターフェイスがジェネリック関数の最小タイプ要件をどのように定義するかを詳しく説明し、タイプの安全性とコードの再利用性を改善します。 この記事では、制限とベストプラクティスについても説明しています

GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか?GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか?Mar 10, 2025 pm 05:38 PM

この記事では、ユニットテストのためにGOのモックとスタブを作成することを示しています。 インターフェイスの使用を強調し、模擬実装の例を提供し、模擬フォーカスを維持し、アサーションライブラリを使用するなどのベストプラクティスについて説明します。 articl

Go言語でファイルを便利に書く方法は?Go言語でファイルを便利に書く方法は?Mar 03, 2025 pm 05:15 PM

この記事では、goで効率的なファイルの書き込みを詳しく説明し、os.writefile(小さなファイルに適している)とos.openfileおよびbuffered write(大規模ファイルに最適)と比較します。 延期エラー処理、Deferを使用し、特定のエラーをチェックすることを強調します。

Goでユニットテストをどのように書きますか?Goでユニットテストをどのように書きますか?Mar 21, 2025 pm 06:34 PM

この記事では、GOでユニットテストを書くことで、ベストプラクティス、モッキングテクニック、効率的なテスト管理のためのツールについて説明します。

トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか?トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか?Mar 10, 2025 pm 05:36 PM

この記事では、トレースツールを使用してGOアプリケーションの実行フローを分析します。 手動および自動計装技術について説明し、Jaeger、Zipkin、Opentelemetryなどのツールを比較し、効果的なデータの視覚化を強調しています

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール