InfoQ

InfoQ

News

マイブックマーク

ブックマークするためにログイン または 会員登録 する

ブックマークされました!

ブックマークがエラーになりました。もう一度お願いします。

状態のPOSTが適切なのはどういうとき?

作者 Dilip Krishnan , 翻訳者 菅野 裕 投稿日 2009年4月15日

セクション
設計/アーキテクチャ,
エンタープライズ・アーキテクチャ
トピック
SOA ,
REST ,
設計 ,
デザインパターン

原文(投稿日:2009/4/2)へのリンク

Tim Bray氏がある記事で(リンク)Sun CloudのAPI (リンク)の最初の公開ドラフトからのフィードバックについて検討している。彼はその記事でフィードバックに対して回答する中で、クラスターにVMを作るといった相互作用のモデル化の方法について、RESTfulな方法を検討した。

彼はSunのクラウドAPIの設計というコンテキストにおけるいくつかのシナリオを挙げ、そのような相互作用をモデル化するのに状態をPOSTすることが適切な方法なのかどうかを問いている。

しかし実際に状態を変更させようとするわけではありません。要求したのは一連の特定のアクションであり、結果として状態が目的とする値に達したり、または達しなかったりするのです。たとえば、「デプロイ」スイッチを押せば状態は「デプロイ中」に変わり、そして幾ばくかの時間が経った後「デプロイ完了」になります。また「リブート」操作も赤い大きなスイッチを持っている、同じ側の典型的な例です。問題なのは、このスイッチをどうやって押すかです。

私は考えれば考えるほど、これらのリソースはボタンのようだと思えてきます。定義された操作は1つだけ、「押す」だけです。人々は「write-onlyなリソース」のことに愚痴をこぼしてきましたが、私にはこれは間違いないものであり問題とは思えません。リブートや停止ボタンはいかなる状態も実際にはもっておらず、そのためGETでいかなる有用な情報が得られることを期待すべきではないのです。

Bill de hÓra氏はこの記事に反応し(リンク)、例を挙げながらPUTとPOSTの違いと、一方が他方より適切であるのはどの場合かを説明している。

どのようなときにPUTとPOSTが実際に重要となるのでしょう?私が自信を持って言える限りでは、扱うリソースがコレクションのときです。これは非常にありふれています。フォルダーやアルバム、フィード、コレクション、ブログ、タグクラウド。注文、ショッピングカートなど、あらゆるリストベースの構造です。

彼はまた議論全体のより実践的な側面を示し、1つの解決法としてフォームをPOSTすることを提案している。

一方で多くの、非常に多くの人がREST/HTTP/AtomPubの深い領域のこと気にしておらず、また気にしようともしていません(またはできません)。私たちに必要なのは開発者がすぐに使えるようになるパターンとプラクティスではないかという考えを私はいくらか感じています。

しかし現状ではRESTコミュニティの専門家である私たちも、リソースを部分的に更新するよい方法やデザインパターンを持っているとは言えません。それが提供できるようになるまでは、もっとも簡単で、すでに配備されたクライアントライブラリやWebフレームワークで広く利用できるアプローチであるフォームのPOSTが使われるだろうと予測しています。そうでなければ、部分的な更新のための特別なメディアタイプを定義するかです。

Roy Fielding氏も同様に記事に対して反応している(リンク)

(私の主張において)メソッドの利用における厳密さに欠ける主な理由は、HTTPで定義されるメソッドがWebアーキテクチャの定義の一部であり、それがRESTアーキテクチャの方法ではないからです。個別のメソッド定義は(中略)RESTアーキテクチャスタイルのことを問題にはしていないし、それについて議論するのは難しいのです。唯一RESTが要求しているのは、すべてのリソースを統一されたメソッドで扱えることなのです(言い換えれば、仲介者はリクエストの意味を理解するためにリソースの型を知る必要がないのです)。

POSTが問題になるのは、他のメソッドが理想的に適している状況で使われるときだけです。他のメソッドが仲介者にとってより価値あるものになるのは、それらが失敗を自動で処理する方法や中間キャッシュがそれらの振る舞いを最適化する方法について何かしら表現しているからです。POSTはそのような特徴を持ちませんが、それが私たちがPOSTなしでいられることにはなりません。POSTはHTTPにおいて、「統一する価値のないアクション」といった汎用的なものを含むたくさんの有用な目的を果たしています。

Roy氏は彼の回答として次のようにまとめています。

私たちはHTTPの状態変更のすべてのPUTを使う必要はありません。RESTはそうすべきとは決して言っていません。(中略)個人的には、そのようなボタンにはPOSTを使うでしょう。APIは、クライアントがより大きなリソースの状態表示をリフレッシュすべきだというメッセージを含めて応答することで、POSTの利用を埋め合わせることができます。言い換えると、303レスポンスを返してそのVM状態の表示へリダイレクトすることで、クライアントは状態が変わったことを知ることができるのです。

元の記事はこちら (リンク)にて、コミュニティの反応も一緒に読むことができる。

特集コンテンツ一覧

GAE開発の落とし穴

Googleのクラウド環境をつかったGoogle App Engineによる開発するにあたり、初めての試みで苦悩する開発者達の経験をもとに、各開発フェーズにあわせて問題点やどう解決したかをご紹介します

イベントレポート:「Coqチュートリアル#1」

去る1月12日、定理証明支援系ツールCoqの初心者向けチュートリアルが開催さ れた(http://kokucheese.com/event/index/23667/)。今後も2月2日 (http://kokucheese.com/event/index/23744/)、2月9日、2月16日と引き続き開 催されていく予定である。本記事では、開催の様子をレポートする。

Javaの未来についてのNeal Gafter氏とのディスカッション

Choosing Options

Neal Gafter氏はOracleによるJava買収の影響に関する議論、Javaにセグメンテッドスタックやメタオブジェクトプロトコルを追加することについての主張、そしてJavaとC#との比較について話をしてくれた。

Google Dartのエッセンス:アプリケーションの構築、スナップショット、Isolate

GoogleはVMをともなう新しい言語であり、JSコンパイラでもあるDartをプレビューした。 InfoQはDartのアプリの構築に貢献する文法の裏側を探った:スナップショット、Isolate、モジュール方式

CSPベースのモデル検査ツール「Process Analysis Toolkit」

本記事ではCSPベースの「マルチドメイン・モデル検査ツール」である、PAT(Process Analysis Toolkit)について紹介する。モデル検査は、形式手法(Formal Method)という方法論を基礎とする技術であり、複雑さが増大しながらも安全性を求められる、現在のソフトウェア開発の状況に対する処方箋の1つとして注目されている手法である。

Jenkinsによる継続的インテグレーションのススメ(4) ~CloudBeesでJenkinsをサービスとして使う~

前回まで、Jenkinsの幾つかの側面に注目して解説をしてきました。シリーズ最後の今回は、Jenkinsをサービスとして使う方法を紹介します。

書籍『抽象によるソフトウェア設計-Alloyではじめる形式手法-』の紹介

Alloyは、MITにて開発された仕様記述言語であり、ツールによる自動解析を使い、インクリメンタルに形式仕様が書けることが特長である。筆者らはAlloy開発者による、Alloyを使った形式手法入門書を翻訳、今夏にオーム社より刊行した。本記事では、Alloyの簡単な概要と、翻訳書『抽象によるソフトウェア設計』(「Alloy本」)を紹介する。

Windows デバイスで開発するタッチユーザーインターフェイス

スマートフォンを中心としたマルチデバイスにおけるタッチユーザーインターフェイスへの対応は、既に必須の項目となりつつある。本記事では、Windows デバイスにおける UX のベースとなっている「メトロ」というデザイン言語を掘り下げながら、既存環境を意識しつつもどのようにタッチユーザーインターフェイス開発に取り組んでいくべきであるかについて解説していく。