InfoQ

新闻

Thomas谈REST Describe & Compile

作者 Stefan Tilkov译者 郭晓刚 发布于 2007年6月21日 上午2时7分

社区
SOA
主题
REST
标签
WADL,
代码生成

Thomas Steiner已经发布了REST Describe & Compile工具的0.3版。这个工具可根据现有的REST消息构建出WADL描述,并可进一步生成多种语言的代码。这次的新版本增加了生成Java代码的功能(之前已可生成PHP、Ruby、Python和C#代码)。要想对REST Describe & Compile工具有个初步了解,你可以试试它的在线版本;你也可以下载它的源码。这是一个Java程序,其中使用了Google Web Toolkit

Thomas跟InfoQ通过E-mail进行了一次简短的问答,以解答关于方法和工具使用上的一些最显著的问题。

InfoQ:你能不能给我们作一个简要的概括——用两句话介绍REST Describe & Compile?

Thomas Steiner (TS):WADL跟REST的关系等同于WSDL跟SOAP的关系。WSDL有Axis和WSDL2Java工具,REST则有REST Describe & Compile,它是一个很酷的WADL生成工具,以及WADL到任何语言的代码生成工具。差不多是任何语言;-)

InfoQ:这跟Google有什么关系?

TS:这是我在Google做的毕业设计,不过它不是正式的Google产品。我在实习期间是作为Google的临时员工工作,最近又跟Google签了一份从10月份开始的全职工作合同。

InfoQ:你是打算即时生成服务描述,然后用“契约先行”的方式来使用它们?

TS:只要在头脑中构想出URI的结构,你就可以用“事例驱动”的方式来构建服务。然后不费吹灰之力就得到WADL描述和代码。将来你的服务打算支持哪些请求,你就准备一组事例,把它们丢给工具,就可以得到WADL和任何语言的客户端代码。

InfoQ:你对于认为代码生成是罪恶的观点看法如何?

TS

/**
* 本文件由REST Compile自动生成。
* 你不应该修改本文件,除非你知道自己在做什么。任何修改
* 都有可能造成严重破坏,甚至摧毁你的电脑。
*/

除此之外,代码生成让你能够非常快速地对契约更改作出响应。修改服务描述,运行代码生成器,你的工作就完成了。代码生成有助于全面保证一致性,当你只需要维护生成器而不用动任何一个文件时,维护也变得更简单。这跟做爱很像,只有当你真正享受过之后你才能说出好在哪里。

InfoQ:你对“REST是否需要一个描述语言”这场争论的观点如何?

TS:老实说,我觉得大家对于什么是REST,什么是RESTful,什么是用REST伪装的WS-*,太过庸人自扰了。我觉得问题不在于HTTP方法是如何映射到CRUD的,对这些问题大家已经讨论了很久。我更同意Nelson Minar的观点:“怎么行得通就怎么做”。没有什么REST不REST的做事方式,只有一家企业的做事方式。有时候一家企业被另一家买下了,突然间企业里就有了两种做事方式。看看Yahoo!、 Flickr和Del.icio.us就知道了。他们的API都很棒,也确实运作得很好。有些API完全不需要身份认证,另一些则强制HTTP认证,而大多数服务都有某种形式的令牌参数(Token Parameter)。问题在于没有一种通用的机器能识别的方式来描述这些东西。WADL可能跟WSDL描述服务的方式很相似,但谁又在乎呢?规范差不多14页那么长,你可以读它,理解它,甚至真的实现它。Marc Nottingham做了一个WADL到HTML的转换工具,Marc Hadley也有一个WADL工具(现在属于SUN),终于,现在有了REST Describe & Compile。可能WADL不是Web Service的万能药,但它的用处是实实在在的。它让你能够完成你的工作,管它是不是纯粹的REST,是不是POX,是不是RESTful,或者其它什么东西,能用就行。

InfoQ:你对未来的版本已经有什么计划了吗?

TS:目前程序完全在客户端运行。这样做有很多优点,但是,长远来说,这限制了它的能力。可能有一天会出现一个WADL2Anything的在线服务,大家向它发出WADL请求就可以传回生成的代码。人们应该能够把他们的WADL存储在网上,让其他人免费使用。就像是Web Service版的CDDB(译者注:CDDB是提供唱片资料的网站)。这是比较接近幻想的计划,首先要完成的还是一些实在的目标:提高代码生成能力,增加对XML Schema的支持,改进语法高亮,让REST Compile模块支持更多更多的语言……

InfoQ:非常感谢!

查看英文原文:REST Describe and Compile

1 条回复

回复

REST Describe & Compile 闲来无事非官方非专业中文版 发表人 fisher luo 发表于 2008年4月15日 下午7时59分
  1. 返回顶部

    REST Describe & Compile 闲来无事非官方非专业中文版

    2008年4月15日 下午7时59分 发表人 fisher luo

    http://wadl.49city.net ;)

独家内容

从卓越工程角度看微软中国开发团队的成长

开发团队的成长离不开优秀的人才,简捷有效的流程和高效率工具这三个卓越工程系统中的重要因素。本文作者从这三个因素分析了微软中国开发团队是如何“从优秀到卓越”的。

利用Ruby简化你的Java测试

本文是Productive Java with Ruby系列文章的第一篇,我将从单元测试这个话题开始,让Java的开发人员能够在实际工作中利用Ruby提高工作效率。

与赵进聊SaaS

InfoQ中文站有幸与阿里软件的首席架构师赵进在一起探讨了SaaS的相关话题,包括SOA和ASP与SaaS的异同、云计算、SaaS的前景、它的关键技术、技术瓶颈等等。

在ESB中选择路由还是编配?

在这篇文章中,Adrien Louis和Marc Dutoo在一个典型的ESB场景中讨论了编配和路由的区别和优缺点。他们讨论了几种连接服务的方法,从使用如自定义路由这样的低级别方法,到使用如工作流和编配这样面向业务的高级别方式,并总结说不存在“一边倒”的解决方案。

分布式系统中的一致性和可用性

本文是根据7月26日InfoQ中文站在杭州举行的QClub活动(第三期)后半程小组讨论总结而成。主要内容包括如何在SOA系统中实现服务编排,如何保证分布式系统中的一致性和可用性,以及如何在实施SOA的过程中控制接口的粒度等。

虚拟化导论

人们很容易想当然的以为虚拟化技术仅仅应用于服务器。而在现实中,虚拟化这一苏醒的概念正被运用于各个层面,其中包括网络,存储以及应用基础架构。在这篇导论中,InfoQ将深入每个方面,详尽向您描述虚拟化技术的运用以及其优点与不足。

用户故事估算技巧

作为开发者,同时也是ThoughtWorks的咨询师,Jay Fields总结了自己估算用户故事的有效技巧。

InfoQ案例研究:纳斯达克市场回放

在这篇案例研究中,InfoQ对Adobe AIR和Amazon的简单存储服务(Simple Storage Service ,S3)在NASDAQ市场回放程序(NASDAQ Market Replay)中的应用进行了详细的分析。