写点什么

JSR 311 最终草案:RESTful Web 服务 Java API

  • 2008-09-26
  • 本文字数:1718 字

    阅读完需:约 6 分钟

去年 2 月, Sun 宣布了 JSR 311 :RESTful Web 服务的 Java API。9 月 23 日,规范的 1.0 草案通过了JCP 执行委员会的赞成投票,这基本意味着它现在已经定稿。

JAX-RS 是 Java 中用于实现以 HTTP 为基础的 RESTful Web 服务的 基于注解的 API。本质上,注解类和方法的信息能让运行时(Runtime)将它们暴露为资源,这种方法和通过 Servlet 编程模型来暴露类与方法的做 法有很大区别。实现 JAX-RS 的运行时(Runtime)周旋于 HTTP 协议和 Java 类之间,考虑 URI、被请求和被接受的内容类型和 HTTP 方法。 除了 Sun 提供的参考实现 Jersey 之外,可用的其他实现(尚在不同的完成阶段)包括:流行的 Restlet 框架的一部分, JBoss RESTeasy 项目 Apache CXF Web 服务栈的一部分。

InfoQ 采访了规范带头人,Sun 的 Marc Hadley Paul Sandoz ,请他们畅谈了他们对 JAX-RS 和整个过程的想法。

被问到他们对这个结果的心情时,Mark 表示他对 API 最终完成非常满意。他还表示,非常幸运的是,在专家组从事 API 设计时就有如此多的实现被构 建出来,并且这有助于抚平 API 中的任何不足。Paul 补充说,不少开发者自愿在 API 的各个版本上工作,采用测试驱动的方式去实现,并提供反馈。

在问及最具挑战性的方面时,Marc 指出,一开始很难在 API 的风格和范围上达成统一:

为了启动这个 JSR,我们以一个涉及面很广的提案开了个头。但是,回想起来,我认为我们可能从一个更具体的方面开始构建更好。
在过去的几个月内,我们已经看到了大量对这个 JSR 的关注,主要挑战是既保证进度又能适应所有新请求。

Paul 大胆地对 JSR 中“J”的某些方面表示了质疑:

可能这显得有点儿异端,但是有时我发现当前的 Java 语法本身有点挑战性。但是,通过 Java 注解、范型和构造器 (Builder)模式,我认为我们把事情降到了一个非常简洁的水平。而且,方便地使用 Scala 和 Groovy 来书写这种 JAX-RS 应用也是有可能 的,这两种语言都支持与 Java 字节码兼容的注解。

在启动这个 JSR 的时候, REST 社区对它能否符合 REST 的关键原则表示怀疑。Mark 认为这一目标已经达到:

我认为 API 是鼓励资源中立的观点的,它让开发者自己决定他们资源的标识符和他们支持的方法。对内容协商的说明性支持非常好,缺 省的资源生命周期鼓励无状态的方式。如果我必须指出一个弱点的话,那就是它对“超媒体即状态引擎(hypermedia as the engine of state)”支持有限。虽然我们能很好地支持从请求 URI 中抽取信息和构造资源 URI,在表述(representations)中正确使用超媒体这一任务较多的还是留给了开发者自己去完成。

Paul 表示同意:

是的,这可能是最困难的地方了。JAX-RS 提供了大量构造 URI 的方法,但是建模 API 中还没有类似 JAXB 这样的 URI 绑定工具。我认为在这一方面,我们有一些办法可以探索,如 Henry Story 的 RDF 序列化

问及 JSR 311 上的工作是否改变了他对 Web 和 Web 服务的观点时,Mark 表示这印证了他的一个观点,即一个人“无需依赖更复杂的东西就可以用 HTTP 完成一件非常伟大的事”。Paul 指出,REST 发明者 Roy Fielding 的将稀疏位数组(sparse bit array)用于通知便是 REST 可在将来带来惊喜的一个例子。

我们还向 Mark 询问了他期望 JSR 311 如何对即将到来的 Servlet 规范修订产生影响:

JAX-RS 应用可以被 Servlet 容器托管,因此两者默契合作非常重要。JAX-RS 是新的 Servlet 可插性 (pluggability)框架的一个潜在消费者,因此我们正在着手就此提出我们的要求。一个难处理的地方是,JAX-RS 提供了较 Servlet 更灵 活的 URI 到资源的映射方式,这对联合使用说明性的 Servlet 安全和 JAX-RS 来说是个挑战,因此我们也在从事这方面的工作。

最后,Mark 证实 Jersey 不“只是”一个参考实现,而且完全可作为产品使用,并且已经有实际的部署了。他还指出,Jersey 将是 Glassfish JSR 311 实现,而这正是 Jersey 需要达到产品质量的原因。Paul 强调了另一原因:

定期发布规范和实现的试验版本(early access)一个好处就是,这让 APT 和实现都能及早和频繁地接受测试的考验:-)

你可以联机阅读这个规范 Jersey 参考实现可从 java.net 获得,并在 Java 5 或更高版本上运行。

查看英文原来: JSR 311 Final: Java API for RESTful Web Services

2008-09-26 21:572956
用户头像

发布了 255 篇内容, 共 56.7 次阅读, 收获喜欢 10 次。

关注

评论

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

区块链与物联网融合发展的机遇与挑战

CECBC

人工智能

电动汽车的小历史及汽车方面的一个基础概念 (28天写作 Day5/28)

mtfelix

28天写作 电动汽车

28 天带你玩转 Kubernetes-- 第五天(玩转Docker)

Java全栈封神

Docker Kubernetes k8s 28天写作

JFR定位线上问题实例 - JFR导致的雪崩问题定位与解决

AI乔治

Java 架构 线程

面试被问AQS、ReentrantLock答不出来?这些知识点让我和面试官聊了半小时!

Java鱼仔

Java 面试 并发 JUC

分布式唯一ID解决方案-雪花算法

JavaPub

Java 分布式

关于时间管理的思考

.

28天写作

外行话之不玩游戏,怎么做好游戏?

Justin

游戏 28天写作 外行话

CSS13 - 定位

Mr.Cactus

html/css

28天瞎写的第二百一六天:LumaQQ 和 luma 二三事

树上

28天写作

项目管理系列(1)-如何开好一个周会

Ian哥

项目管理 28天写作

甲方日常 84

句子

工作 随笔杂谈 日常

Deno 双周刊 #1 - Deno 获 2020 JS 开源年度突破奖

hylerrix

typescript deno Node 周刊 V8

时间之外的颜色「幻想短篇 5/28」

道伟

28天写作

聚焦目标,团队工作不再一盘散沙(上)

一笑

管理 敏捷 目标管理 28天写作

夜莺二次开发指南-用户资源中心

ning

滴滴夜莺 夜莺监控

【Mysql-InnoDB 系列】事务模型

程序员架构进阶

MySQL 架构 innodb 事务 28天写作

读书笔记:《Remote》

lidaobing

28天写作 Remote

读《百度不需要用户》,我似乎懂得了领导者的无奈

李忠良

AI 企业

【Mysql-InnoDB 系列】关于一致读

程序员架构进阶

MySQL 架构 innodb 28天写作

一文学会Java死锁和CPU 100% 问题的排查技巧

AI乔治

Java 架构 死锁 cpu 100%

Experience Never Gets Old

三只猫

28天写作

未来五年数字经济九大技术趋势,区块链成数字时代刚需!

CECBC

人工智能

线程池是怎么回收空闲线程的?如果你认为有定时任务,那你就错了!

看点代码再上班

Java 程序员 后端 开发

如何让开发人员接受DevSecOps

啸天

DevOps 开发者 DevSecOps 升职加薪 应用安全

小马哥刷力扣 - LeetCode 9. 回文数

小马哥

LeetCode 算法和数据结构 28天写作

一次慢查询暴露的隐蔽的问题

AI乔治

Java sql 架构 SQL优化

夜莺二次开发指南-资产设备管理

ning

滴滴夜莺 夜莺监控

发达国家加紧数字货币政策布局

CECBC

数字货币

一文带你快速入门Canal,看这篇就够了!

大数据老哥

大数据 实时数仓 canal

夜莺二次开发指南-监控系统(3)

ning

滴滴夜莺 夜莺监控

JSR 311最终草案:RESTful Web服务Java API_Java_Stefan Tilkov_InfoQ精选文章