Bru*_*nes 2 rest ruby-on-rails
我有一个Rails应用程序需要将数据库中的值作为Web服务公开 - 因为我正在使用Rails 2.x,我将使用REST(或至少尝试).假设我的资源是Bananas,我想为其揭示几个子特征,请考虑这个:
- /banana -> give a summary of the first 10 bananas, in full (all characteristics)
- /banana/?name=<name> -> give all characteristics for banana named <name>
- /banana/?number=<number> -> give all characteristics for banana number <number>
- /banana/?name=<name>/peel -> give peel data for banana named <name>
- /banana/?number=<number>/length -> give length data for banana number <number>
Run Code Online (Sandbox Code Playgroud)
我不希望搜索ID,只有名称或号码.我有大约7个子特征要揭露.这是RESTful吗?
感谢您的任何反馈!
Ric*_*aca 10
Wahnfrieden所谈论的是称为超媒体作为应用程序状态引擎(HATEOAS)的东西 - 由Fielding定义的REST的核心约束.
简而言之,REST应用程序客户端永远不会自己构造URI.相反,它们遵循应用程序提供的URI.因此,诸如您所询问的URI模板充其量只是无关紧要的.如果您愿意,可以使它们符合系统,但REST没有说明您的URI需要如何查看.如果您愿意,可以安排它,以便系统中的每个资源都可以从http://example.com/ {hash}获得.
发布URI模板(例如您在问题中讨论的模板)会引入应用程序和客户端之间的紧密耦合 - 这是REST试图阻止的.
理解超媒体驱动的应用程序的问题在于,几乎没有人以这种方式实现或记录其"RESTful"系统.
通过浏览器考虑人与服务器之间的交互可能会有所帮助.人类只知道服务器通过浏览器提供的内容和链接.这就是构建RESTful系统的方式.如果您的资源没有公开链接,那么它们可能不是RESTful.
优点是,如果要更改URI系统,例如,通过查询参数而不是嵌套URL公开Banana"Peel"属性,您可以随时执行此操作,并且不需要客户端代码因为他们没有为自己构建链接而改变了.
有关在REST中包含超文本驱动约束的系统示例,请查看Sun Cloud API.
我会用这些:
首先,ReSTful URI的常见做法是/ object_name/id/verb,其中一些缺席(但按此顺序).当然,这既不是必需的,也不是预期的.
如果您的所有名称都不是数字,则不必明确地使用name/ banana/name/blah.事实上,如果有的话,最好有id标识符:/ banana/id/123/peel.希望这可以帮助.
| 归档时间: |
|
| 查看次数: |
1253 次 |
| 最近记录: |