Apidog

オールインワン協働API開発プラットフォーム

API設計

APIドキュメント

APIデバッグ

APIモック

API自動テスト

PUTメソッド解説|PUTリクエストを1クリックで実装

PUTメソッドはHTTP基本的なメソッドの1つとして、多くの場合に利用される必要があります。本文では、PUTメソッドの特徴、仕組みなどを詳しく解説した上、非常に簡単な方法でPUTリクエストを実装する方法を皆さんに紹介していきたいと思います。

中村 拓也

中村 拓也

Updated on 11月 12, 2024

PUTメソッドはHTTP基本的なメソッドの1つとして、多くの場合に利用される必要があります。本文では、PUTメソッドの特徴、仕組みなどを詳しく解説した上、非常に使いやすいAPIクライアントでPUTリクエストを実装する方法を皆さんに紹介していきたいと思います。

button

PUTメソッドとは

PUTメソッドはHTTPの基本的なメソッドの1つとして、主にリソースのデータ全置換のために利用されるメソッドです。PUTメソッドのデータ送信方法は、POSTメソッドと同じようにHTTPリクエストボディにデータを追加して送信することになります。PUTメソッドを使う場合、リクエストのURIは更新対象のリソースを特定する必要があります。

PUTメソッドの主な特徴

PUTはリソースの完全な更新に用いられるイデンポテントなメソッドとして、主に以下の特徴があります:

リソースの更新/作成に使用

PUTは対象のリソースを更新するために使われます。リソースが存在しない場合は、新しく作成します。

イデンポテント性あり

同じリクエストを複数回実行しても、結果は同じになります。 PUTはリソースを上書きする性質があるため、リクエストの回数に関係なく結果は変わりません。

リクエストボディにデータを含む

更新するデータや新規リソースの内容は、リクエストボディに含まれて送信します。

全リソースを更新

PUTはリソース全体を上書きします。部分的な更新にはPATCHが利用されます。

URIはリソースを特定

PUTリクエストのURIは、更新対象のリソースを指定する必要があります。

冪等性あり

同じリクエストを何回送信しても、リソースの状態が変わらないことを冪等性といいます。PUTにはこの性質があります。

このように、PUTはリソースの完全な更新に用いられるイデンポテントなメソッドです。

PUTメソッドとリクエストの使用例

PUTメソッドは、GETやPOSTメソッドのように汎用されていないにも関わらず、PUTメソッドの使用が必要となる場面も非常に多くなっています。次は、PUTメソッドとリクエストが必要となる場合を皆さんに紹介します。

REST APIでのリソースの更新

PUT /users/1
{
  "name": "John Smith",
  "age": 35
}

指定したURIのユーザー情報をリクエストボディの内容で上書き更新します。

ファイルのアップロード

PUT /files/report.pdf
<file data>

指定のファイルパスに、リクエストボディのバイナリデータをアップロードします。

データベースレコードの更新

UPDATE table SET 
  column1 = value1, 
  column2 = value2
WHERE id = 1;

主キーで指定したレコードを、リクエストボディの値で更新します。

リソースの作成

PUT /users/2
{
  "name": "Jane Doe", 
  "age": 28
} 

ユーザー2が存在しなければ、リクエストボディのデータで新規作成します。

このように、REST APIではリソースの更新に、ファイルアップロードでは完全な上書きに、PUTメソッドが利用されます。URIでリソースを特定し、ボディに新しいデータを含めるのがポイントです。

PUTとPOSTメソッド:共通点と相違点

上記のPUTメソッドの解説から、多くのユーザーは、PUTメソッドとPOSTメソッドとは一緒ではないのかと思っているかもしれません。確かに、PUTとPOSTはともにサーバー上のリソースを更新するHTTPメソッドですが、実際には、次のような共通点と相違点があります。

PUTとPOSTとの共通点

  • リクエストボディを送信できる
  • 特定のリソースに対する操作を表す
  • 冪等性がない(複数回リクエストしても結果が変わる)

PUTとPOSTとの相違点

  • PUTはリソースの完全な更新、POSTは部分的な更新に使われる
  • PUTはイデンポテント、POSTは非イデンポテント
  • PUTはURIでリソースを指定、POSTはURIでは処理を指定
  • PUTはリソースがなければ作成、POSTは常に新規作成
  • PUTは200または204を返す、POSTは201を返す

PUTは既存リソースの全置換、POSTは新規作成や部分更新に使い分けられます。 URIの意味付けやレスポンスコードも異なります。PUTとPOST両者の違いを理解し、目的に応じて使い分けることも重要です。

button

Apidog:1クリックでPUTリクエストを送信可能!

それでは、もしPUTリクエストを送信してリソースのデータを更新したりする必要がある場合は、どうやって実装すればいいですか?この部分では、日本語対応API管理ツールのApidogで1クリックだけでPUTリクエストを送信できる方法を皆さんに紹介します。Apidogを使って、PUTリクエストを送信すると、送信情報と取得結果を一緒に保存して、API仕様書を作成して、簡単に他のメンバーに共有することも可能になりますので、非常に便利です。

ApidogでPUTリクエストを送信する場合、PUTリクエストのパラメータ、Body、Headerの設定は、Apidogで全部利用することができますし、Bodyでform-data、x-www-form-urlencoded、json、xml、rawやbinaryなどのフォーマットでデータを渡すこともできるので、非常に便利です。

ApidogでPUTリクエストを送信
button
ApidogでバックエンドAPI開発の効率をどう向上させるか?チュートリアル

ApidogでバックエンドAPI開発の効率をどう向上させるか?

ApidogはAPI管理の全体的なソリューションを提供し、定義からデバッグ、ドキュメント作成までバックエンド開発を最適化します。プロジェクトの規模に関わらず、開発者が効率的に作業を完了するのを支援します。

中村 拓也

11月 25, 2024

APIテスト効率化:ApidogでのJSONレスポンス管理法チュートリアル

APIテスト効率化:ApidogでのJSONレスポンス管理法

この記事では、ApidogでJSONレスポンスからアサーション設定、変数抽出、JSONパスのコピー方法を解説しました。APIテストの自動化と効率的なレスポンス検証が簡単になり、データの再利用も可能です。Apidogを使い、API機能を確認しましょう。

中村 拓也

11月 20, 2024

ApidogとAlgolia統合で実現する効率的なドキュメント検索チュートリアル

ApidogとAlgolia統合で実現する効率的なドキュメント検索

本記事は、AlgoliaをApidogと統合し、APIドキュメントの検索機能を改善する方法を紹介します。最適な検索設定を維持しながら、情報アクセスの迅速さと効率性を向上させ、ユーザー体験を向上させます。

中村 拓也

11月 19, 2024