InfoQ

新闻

支持REST设计的WCF Web编程模型

作者 Hartmut Wilms译者 霍泰稳 发布于 2007年5月21日 下午9时53分

社区
.NET,
SOA
主题
Web服务,
REST
标签
WCF,
Orcas

MIX07大会上Don BoxSteve Maine的“浏览可编程Web”联合演讲中,他们介绍了即将随Visual Studio Orcas一同发布的WCF Web编程模型。在统一的WCF编程模型下,Web编程模型从而可以支持Web服务REST化设计的功能。

新的功能可以帮助在没有SOAP封装或者任何WS规范的情况下编写简单的服务。这儿的Web编程模型是以URI和HTTP动词为中心的。为了保持WCF编程模型的延续性,ServiceContract、DataContract和其他的WCF的服务模型等仍然可以使用。新的模型主要位于一个名为WebServiceHost的新WCF服务主机(Host)里,以及有一个新的标准绑定:WebHttpBinding。新功能包括:

  • 通过System.UriTemplate支持URI模板。URITemplate用来定义URI的特定模板。在Joe Gregorio博客里,他描述了URI模板的相关思想。
  • 在要寻找最佳匹配的时候,System.UriTemplateTable可以用于存储一些能和具体的URI相配的UriTemplate数据。
  • 用于服务操作的[WebGet]和[WebInvoke]属性,被WCF调度器(Dispatcher)用来将HTTP请求映射到一个实现方法上。
  • WebServiceHost和WebHttpBinding。
  • System.ServiceModel.Syndication命名空间,增加了对产生和消费RSS/Atom种子的支持。

在Steve Maine关于Web编程模型的讲座中,详细解释了所有的功能:Web编程模型之道一Web编程模型之道二Web编程模型之道三UriTemplate 101UriTemplate.Match等。

根据Jef Newson的说法,DonBox和Steve Maine的演讲代表了微软针对分布式计算的过往实现方法的一种宣泄:

所以,我很有兴趣来观察像Clemens Vasters和Don Box(还有Steve Maine等)这些人开始扔掉WS-Splat的包裹,只是GET它。而且我想他们是很实际的,能很好地抓住这80%的需求(GET),但是他们在通过一种并不严谨的方式增加了一些看上去很好的REST支持。当像“喔,你们不应该再给它增加一个SOAP层吗?”这样的问题被提出来的时候,他们会泰然自若而且平静非凡,说“哈,这儿你们将来不需要它的。”在外人看来,这好像有点滑稽。

他已经小有所成,并写了一些关于他在和Web编程模型争斗时,第一回合第二回合的经验心得。

David Ing称这个对话为“简易对象辩解协议”(Simple Object Apology Protocol),因为“在所有基于架构和编程模型的工作与代码放到SOAP里面后,Web编程模型在本质上是应用协议堆栈的倒退,差不多退回到2002年左右。”他还提到一些在WCF堆栈上增加新模型的风险:

对于“增加一个可选的层,现在我们知道了”这种方法的一个大问题是:许多开发者会引用最新的技术作为解决问题的最新指导。……通过提供这样一个使用什么技术(如REST、HTTP/POX、SOAP和Remoting等)的广泛选择,然后让人们找出“一个简单的答案”,其实只是增加了这一过程的复杂性和迷惑性。那些新东西的复杂性代价开始有点像联邦赤字一样——一直在错误的道路上行走。

Steve Maine通过证明WCF本质上是能够“平衡目标和丰富性(Reach & Rich)”(译者注:Reach指一个运行在所有WEB浏览器上的、不用额外的安装机制的前台终端,Rich是指具有高度互交性的交互式用户接口)这一观点,回应了以上两个不同的说法:

我认为我们现在所做的延伸编程模型工作,在V1里增加了丰富协议堆栈的价值,因为在丰富性和目标之间它远离了传统的场景束缚。以Rails框架为例,使用它做一些通用场景就很容易。当然,Rails差不多只能满足80%的情况。如果因为某种原因,你突然遇到了20%的情况,可能就无所适从了(像Twitter的人所发现的一样)。我们想为那些企图通过采用WCF摆脱在分布式系统上困惑的家伙提供保护。通过提供Orcas Web功能,在这个方向上我们已经取得了很大的进步,相信我们还会走的更远。

就加固在WCF之下开发分布式应用时所用到的全部已知协议和方法的编程模型而言,Web编程模型是一个进步。另外它还是微软真心喜欢REST方法以及在他们的项目路线图里融入REST设计的信号之一:Astoria项目已经基于这种新的模型了。

没有回复

回复

深度内容

Flex与JSON及XML的互操作

平台需要互操作性。在这篇文章中,作者仔细研究了Flex和JSON及XML的互操作性。文章也包含了使用E4X库来将XML映射到图表和表格组件的内容,还演示了如何使用as3core库来解码JSON消息。

用Qi4j进行面向组合编程

本文将简要介绍面向组合编程(COP,Composite Oriented Programming)的概念,展示它如何规避OOP存在的一些问题,并重新点燃使用可重用部件组装领域模型(Domain Model)的希望。

系统开发——新学科,新教育

一门新的计算机学科——“系统开发”,强调人性化、匠艺、设计、创意、创新和新事物的涌现,并建议用被称为“bottega”的工作室替代乏善可陈的教室。

图书聚焦:Visual Studio 2008 揭秘

Mike Snell和Lars Powers用他们最近由Sams出版的新书《Visual Studio 2008揭秘》,试图帮助大家提高开发人员的生产力。本文包括一个下载样章——第10章调试。

BPEL为何不是BPM的圣杯?

Pierre Vigneras在本文中讨论了作为标准之一的BPEL所存在的问题。Pierre先给我们大致介绍了一个简单的并行流程,接着讨论了从业者在试图以一个结构化模型为基础表达非结构化流程时遇到的一系列问题。

基于范型的多语言编程

你是否仔细思考过,为什么人们总在讨论“要正确的语言做恰当的事情”?在这篇文章中,Sadek Drobi向你解释了为什么应该在系统内部混合使用多种语言。

采访与书摘《Pro Web 2.0 Application Development with GWT》

Jeff Dwyer就关于他的新书(《Pro Web 2.0 Application Development with GWT》)、GWT1.5以及创建可搜索的Ajax应用谈了一些他的见解。

时刻准备着,迎接IT业的春天

我们需要设身处地地为客户及客户的业务本身着想,与客户同舟共济。更多创新的思路、产品和模式也同样将为IT业带来新的出路。IT业并不需要坐以待毙,在春天到来之后,市场将会更加繁荣!