【ArchSummit】如何通过AIOps推动可量化的业务价值增长和效率提升?>>> 了解详情
写点什么

是时候将 WADL 加入到 JAX-RS 中了吗?

  • 2012-10-23
  • 本文字数:1536 字

    阅读完需:约 5 分钟

在今年的 JavaOne 上,有一个名为’ JavaEE.Next(): Java EE 7, 8, and Beyond ’ 的专题,包括 Oracle、IBM、Red Hat 以及 Caucho 所组成的小组讨论了 Java EE 的各个方面,并回答了观众的问题。最初预想的焦点会是 Paas、移动开发以及 NoSQL,但是与会者对 REST 尤其是 WADL 也表现出了极大的兴趣。现在,WADL 并不是新鲜事物,它已经存在并被广泛讨论了至少七年的时间,我们在 2005 年曾经这样报道过:

对于那些想在 HTTP 服务上描述 XML 的人来说,已经讨论过很多可选的方案了,从 SMEX-D (Tim Bray 所提出的)到 NSDL ,以及其他众多的可选方案。但是,大多数提议都是在 2005 年甚至更早的时候创建的,从那以后它们都没有较大的改进。 Marc Hadley( JSR-311 规范的负责人之一,这个规范是 RESTful 服务的一种 Java API)在 2005 年 提出了 WADL ——Web 应用描述语言。

从那以后,很多人构建工具来支持 WADL。Yahoo 的架构师 Mark Nottingham 维护了能够从 WADL 生成文档的一个样式表。

就像围绕 REST 的某些事情一样,在过去,WADL 将社区分裂成相信 WADL 必要和非必要的两派。例如,在 2007 年 Mark Baker 曾经这样说:

[…] 所有服务暴露相同的接口。这就提供了大多数的松耦合,这也是与 RPC 的主要区别。 所以如果你正在编写(或生成)协议 / 接口级别的代码,而这些代码不能延迟绑定到所有地方的 _ 所有 _ 资源上,这样做其实不是 REST(对指出这违反了特定约束的人,应该给予莫大的荣光)。

我们已经挣脱了约束!RPC 已死!你不能再为所欲为了!

而喜欢它的人通常将其与 WSDL进行比较

回忆一下 WSDL,它能够很简单地 _ 生成 _ 到 web 服务的交互代码。这一点很棒,可以节省大量的工作。在 RESTful web 服务中,我们同样可以这么做吗?是的,可以的。最终,我的结论就是,你可以借助 WADL 做到这一点。WADL 代表了 Web 应用描述语言,它能够为任意的 web 服务(包括 SOAP web 服务,这可能让你感觉意外)描述基于 HTTP 的 API。但是你还可以用 WADL 描述 flickr API、twitter API 以及 yahoo API。猜一下它能做什么… 它能够生成客户端代理代码来与这些 API 交互。是的,它与 WSDL 很类似,但是更通用。它能够统一支持 REST 和其他任意(我猜)类型基于 XML 的 web 服务。

但正如一位评论者所言,它可能是双刃剑:

在这篇文章中犯了几个根本性的错误。你说"我在这里所叙述的是,结果的格式和发送给 REST web 服务的数据都是精确定义的 XML。那么,当我要求媒体类型的时候会怎样?他们也是精确定义的数据格式,它们与怎样处理数据以及如何基于表述获取新的资源相关。 读一读 Roy Fielding 的作品吧 ; )

顺便说一句,WADL 可能并不会长久,它实际上一点都不 RESTful(在客户端和服务提供者之间建立了紧耦合)。

在 2005 到 2008 的几年间,类似这样的争论在REST 领域泛滥。最近,争论似乎逐渐平息,出现了更务实的前景。有些组织觉得,尽管WADL 还有一些问题(如它是否RESTful),但对于开发者而言,它应该是一个要支持的方案。而另外一些组织则完全避开了它。例如JAX-RS 的参考实现Jersey 就内置支持了WADL 。而另一些 JAX-RS 实现,如 RESTeasy 就没有这样明确支持

让我们回到JavaOne 这个专题上来,很多观众包括JAX-RS 规范的负责人,都很想知道未来版本的JAX-RS 是否要完全支持WADL。然而讨论小组未置可否,并提及很多成功的RESTful 服务并没有使用WADL,但是很多观众倾向于支持将WADL 加入到JAX-RS 中。鉴于最近几年WADL 的影响力处于低潮期,这会不会是Java 和JAX-RS 的特殊需求,WADL 会不会再次得到关注呢?如果是这样的话,WADL 会不会使得现在开发的RESTful 服务和应用程序比几年前的更好呢?会不会使得今天的开发人员比以前更务实呢?

查看英文原文: Is It Time For WADL in JAX-RS?

2012-10-23 02:191888

评论

发布
暂无评论
发现更多内容

摩尔时代如何押注AI算力?英特尔战术大揭秘

科技新消息

论坛接口测试——Postman数据驱动(超详细小白教程)

程序员阿沐

编程 程序员 软件测试 自动化测试 接口测试

译文 | 四张画布教你判断「产品开发优先级」

LigaAI

产品经理 产品开发 画布 产品优先级

简述 Linux I/O 原理及零拷贝(上)— 磁盘 I/O

Qunar技术沙龙

Linux 缓存 Mmap 磁盘 I/O

ipfs矿机公司星际联盟是什么公司?星际联盟ipfs矿机靠谱吗?

分布式存储 IPFS Filecoin ipfs挖矿 ipfs矿机

终于有大牛把Spring微服务架构设计第2版文档给整理完毕了

公众号_愿天堂没有BUG

Java 编程 程序员 架构 面试

MySQL 不完全入门指南

Java 编程 架构 面试 架构师

影像篡改与识别(一):胶片时代

腾讯安全云鼎实验室

影像 暗房技术 篡改识别

解密优酷智能生产技术,看 AI 赋能内容数字化

阿里云视频云

音视频 短视频 视频处理 视频制作 视频云

石油行业数据采集中的 MQTT 协议

EMQ映云科技

数据 mqtt emq 远程监控 实时数据

DEX去中心化交易所自动刷量机器人开发|去中心化做市机器人

Geek_23f0c3

去中心化交易所系统开发 量化交易机器人系统开发 量化机器人 做市机器人 自动刷量机器人

堡垒机和跳板机的三大区别分析-行云管家

行云管家

运维 堡垒机 IT运维 跳板机

文件上传绕过思路拓展

网络安全学海

黑客 网络安全 信息安全 渗透测试 安全漏洞

fil挖矿怎么挖?fil挖矿成本是多少?

fil挖矿怎么挖 fil挖矿成本是多少

没有7年经验你真学不会这份SpringCloud实战演练文档

公众号_愿天堂没有BUG

Java 编程 程序员 架构 面试

由阿里三位专家撰写:数据库高效优化:架构、规范SQL技巧文档

公众号_愿天堂没有BUG

Java 编程 程序员 架构 面试

20年IT老民工苦心编撰成超大流量分布式系统架构解决方案文档

公众号_愿天堂没有BUG

Java 编程 程序员 架构 面试

DEX去中心化交易所自动刷量机器人开发|去中心化做市机器人

量化系统19942438797

去中心化 做市机器人

一文带你掌握 OceanBase 社区版部署细节及原理

OceanBase 数据库

数据库 分布式数据库 oceanbase OceanBase 开源 OceanBase 社区版

软件测试框架之——Postman参数化(超详细小白教程)

程序员阿沐

软件测试 自动化测试 接口测试

如何优雅的在业务中使用设计模式(代码如诗)

小呆呆666

flutter android 大前端 设计模式

短视频询盘获客系统开发案例解析

获客I3O6O643Z97

抖音、快手获客系统 抖音矩阵拓客

入职京东:成功拿到offer薪资30K「面试经历+面试真题」

今晚早点睡

Java 秋招

微服务的痛:你的微服务还好吗?

我爱娃哈哈😍

架构设计 架构设计实战

立于山巅!他,凭什么抗住万亿级流量冲击!

博文视点Broadview

webrtc BitrateAllocator 带宽分配器

webrtc developer

WebRTC

❤️专科出身拿到阿里offer,我直呼666!【付硬核面试】❤️

编程susu

Java 编程 程序员 面试 计算机

华为高级技术专家多年经验分享微服务治理体系、架构及实践文档

公众号_愿天堂没有BUG

Java 编程 程序员 架构 面试

【等保测评】黑龙江等保测评机构详细信息说明

行云管家

网络安全 等保 等级保护 等保测评

简单、快捷、低成本的超写实虚拟人平台来了……

百度开发者中心

人工智能 AI 最佳实践 虚拟人 前沿技术

fil矿机1T一天可以挖多少币?fil矿机能挖多久?

fil矿机能挖多久 fil矿机1T一天可以挖多少

是时候将WADL加入到JAX-RS中了吗?_REST_Mark Little_InfoQ精选文章