1. REST Service虽然实现简单, 但也功能丰富, 可以用来实现各种基于Web的服务(service)。
2. REST Service的一些特点:
1)平台无关
2) 语言无关
3)基于HTTP标准
4)即使有防火墙存在的情况下也可以方便使用。
3. REST 没有提供内建的Security features, encryption, session management, QoS guarantees, etc.
但是在提供REST Service的时候,可以使用基于Http之上的安全措施:
OAuth
HTTPS
etc.
4. REST和SOAP相比的简单之处:
SOAP的请求信息
<?xml version="1.0"?> <soap:Envelope xmlns:soap="http://www.w3.org/2001/12/soap-envelope" soap:encodingStyle="http://www.w3.org/2001/12/soap-encoding"> <soap:body pb="http://www.acme.com/phonebook"> <pb:GetUserDetails> <pb:UserID>12345</pb:UserID> </pb:GetUserDetails> </soap:Body> </soap:Envelope>
通常包含在Envelope之中,这需要我们先解析Envelop中的信息。
对于SOAP只需要
http://www.acme.com/phonebook/UserDetails/12345
REST的一些优势
- It's easy to see why Web Services are often used with libraries that create the SOAP/HTTP request and send it over, and then parse the SOAP response.
- With REST, a simple network connection is all you need. You can even test the API directly, using your browser
一个形象的例子:
SOAP就好像是邮递信件需要信封将信件wrap起来。
而是用REST就好像是一个明信片(每次请求是用更少的带宽,因为减少了信封(SOAP的包装信息)), 当然在安全性上可以使用任何加密手段保证安全。
5. 复杂请求, 前文说到只读信息推荐使用GET请求, 但是对于复杂请求,需要很多参数和信息的情况下 (HTTP协议本身未指定任何对URL长度要求。它只是建议不要超过255个字符), 这种情况下可以使用POST请求来得到资源的Representation。
6. 不同于SOAP, REST的相应不局限在XML, 可以使用JSON, CSV等其他格式。可以针对不同情况利用这些文档的优势。
XML更易于扩展。
CSV具有更好的压缩性。
JSON更易于Java Script处理。
HTML推荐作为REST的返回格式,出了在需要Human-Readable的情况下, 大部分情况返回信息是用程序来处理的。
7. REST的核心架构:
资源(Resource)
A web of resources(返回信息不能过大, 必要时使用分页paging),之前做过的一个项目就发生过返回信息过大而time out的情况。
无连接状态(No Connection state)
必要时缓存 (使用 Http cache-control Header)
使用代理服务改善性能。
8. REST设计纲领:
1)不要使用物理URL,例如指向具体的问题文件
2) 返回信息不能过大(分页)
3) 完善返回信息文档(例如返回信息xml的DTD
4) 返回列表具体resource的URI,
返回所有用户信息, 例如
<users>
<user>
.....
</users>
5) GET请求不能引起资源(Resource)状态变化。
9. ROA vs.SOA, REST vs. SOAP
1) 基于SOAP based的SOA相对于ROA可能有更多成熟的工具的支持。(这种情况可能随着时间的推移而改变)
2) ROA更易于实现
3) ROA具有更好的性能, -- 更好的Cache支持, 更轻量级的Request和Response。