答えて
これはあなたの責任です。あなたはそれを理にかなって、可能な限り永続させるべきです。
例:usernameの
/users/john.doe
とユーザーの収集のため
/users
。
次のようなものを行うためにURLの階層的な性質を活用する必要があります。ユーザーのドキュメントのリストを参照するには
/users/john.doe/documents
。あなたはこれをどのように構造化するかに非常に注意する必要があります。リソースURLは、サービスの最も重要な設計上の決定事項の1つであるため、設計の潜在的な影響について慎重に検討してください。
ハイパーメディア制約を尊重すると、リソースURLの「デザイン」はクライアントの機能とは無関係です。サーバーは、クライアントを壊すことなくいつでも変更することができます。 –
RESTのURLは、子供が名前を付けられたのと同じ方法で定義されています:家族名(既存の企業またはプロジェクトの標準)を使用する人もいれば、赤ちゃんの名前の本を参照する人もいます(赤ちゃんのスミス)のような既定の名前を使用し、退屈な名前を変更するプロセス(後で301のリダイレクトなど)を経なければならない人もいます。彼らが納品日までに選んだ名前。
要するに、実際に典型的なものはありません。標準フォーム生成URL(?name = value &のname = valueパラメータ)は完全に有効なREST URLです。多くの人は、http://example.com/restapi/name/value/name/valueのようなスラッシュのパスに、または暗黙の位置名http://example.com/restapi/value1/value2のように、これらのパラメータをエンコードすることを好みます。しかし、あなたは決してそれらの形式に制限されません。
しかし、あなたが好きです。 URLが完全に不透明であったり、URLのパスがどのような種類のリソースを必要とするかを伝えることができます。
HATEOASの原則に従い、配信しているハイパーテキストのURLにアクセスして、特定のURLを構築する方法ではなく、ナビゲートする方法のみをクライアントが知りたい場合があります。
I.e.ルートURLを開始し、他のすべてのリソースをそこからのナビゲーションで到達可能にすることができます。 自分自身を特定のURLテンプレートに縛らないでください。これは、REST APIを拡張して改善する能力にのみ影響します。
RESTは、分散システムを構築するためのアーキテクチャスタイルです。一般的には、クライアントアプリケーションとサーバーアプリケーションがあることを意味します。クライアントアプリケーションがサーバー上の情報にアクセスする必要がある場合は、その情報を識別するために使用できるURLを作成します。
URLの構造はクライアントアプリケーションにとって本当に重要ではないため、使用しているサーバーフレームワークで最も簡単な構造を使用してください。
- 1. #this.datasource#は通常どこに定義されていますか?
- 2. ember.containerviewは通常のビューのように定義されていますか?
- 3. 通常$ GEM_PATHはどこに設定されていますか?
- 4. time_tはどのように定義されていますか?
- 5. マクロはどのように定義されていますか?
- 6. 通常、ヒープはどのように実装されていますか?
- 7. BRDFは通常どのように実装されていますか?
- 8. このFlexフロントエンドアプリケーションがバックエンドアプリケーションにどのように接続されていますか? mx:RemoteObject URLエンドポイントURLはどこに定義されていますか?
- 9. ggplot2 plus演算子はどのように定義されていますか?
- 10. 通常、ビューポートサイズはどのように引数として渡されますか?
- 11. これはどのように定義されていますか?
- 12. Torch7はPytorchのように定義されていますか?
- 13. ここで、/ toはどのように定義されていますか?
- 14. Laravel Slack Webhook URLはどこに定義されていますか
- 15. Oracleではスキーマはどのように定義されていますか?
- 16. 実際にPythonデコレータはどのように定義されていますか?
- 17. コマンドラインツールのハンドルバーブロックヘルパー関数はどのように定義されていますか?
- 18. zvalのようなものはどこに定義されていますか?
- 19. ECMAScriptの内部プロパティはどのように定義されていますか?
- 20. (、)はどのように内部で定義されていますか?
- 21. サンプルサイズはQAPテストでどのように定義されていますか?
- 22. PageRank - リンクはどのように定義されていますか?
- 23. WSO2のAPIマネージャは、私はREST APIのURLが定義されている
- 24. DevToolプロトコルによって提供される `resourceType`値はどのように定義されていますか?
- 25. クラス "セクション"はどこに定義されていますか?
- 26. 角2:url 'api/heroes'はどこに定義されていますか?
- 27. 私のように定義された通知持っ通知
- 28. Mavenプロファイルに基づいて特定のREST Urlをヒットするにはどうすればよいですか?
- 29. モデルは通常ViewModelオブジェクト間でどのように共有されますか?
- 30. EasyAutocompleteイベント - $(これ)は常に定義されていません
「URL」は「ユニバーサルリソースロケータ」と定義されているため、「ユニークURL」は「ユニバーサルユニバーサルリソースロケータ」となります。 –