REST相关技术解析与实践
1. HTTP+POX概述
REST在企业级面向服务架构应用的推广中面临诸多挑战。严格的四个HTTP动词使用规则,以及资源需传输到客户端进行逐块处理的要求,都给其应用带来了困难。此外,浏览器对这四个动词的支持有限,资源URL缺乏既定规范,内容类型指定方式不统一(如ActiveRecord不符合规范),这些都使得REST的应用体验不佳。
不过,在Rails领域之外,一种REST的变体——REST+POX正逐渐流行。其中,POX代表普通老式XML(Plain Old XML)。这种变体并不因面向过程的应用无法与GET、POST、PUT和DELETE映射而否定其存在的必要性。它能实现XML - RPC的所有功能,还避免了XML - RPC在HTTP之上额外增加的间接层。
在HTTP+POX中,基于资源的方法适用时,会采用REST约定,像ActiveResource能实现的功能都属于此类。而对于需要面向过程方法的问题,如确保服务器能在数据库事务中封装过程,或在不将所有数据传输到客户端的情况下完成任务,就会采用POX约定。POX是一种通过URL访问的方法,它接受参数并以XML格式返回结果。传入的参数可以是XML编码的完整数据结构,本质上是多年来开发的服务器端操作,只是增加了复杂数据作为参数。HTTP+POX中的“普通老式XML”将XML - RPC中隐藏在端点URI后的过程操作回归到了更底层的HTTP层。通常,人们所说的RESTful指的就是这种方式。
2. 定义服务契约
尽管REST的概念提出已久,但在构建Web服务的实践中仍处于起步阶段,对于如何最佳实现RESTful服务,REST支持者们尚未达成共识。
超级会员免费看
订阅专栏 解锁全文
168万+

被折叠的 条评论
为什么被折叠?



