Java API for RESTful Web Services 2.1发布

Java API for RESTful Web Services JAX-RS 2.1于本周发布。据Oracle技术小组首席成员及JSR规范牵头人Santiago Pericas-Geertsen介绍,JAX-RS 2.1中包括对服务器发送事件(SSE,Server-Sent Event)和JSON-B的支持,并改进了对JSON-P的支持。该API给出了对客户端API的响应式扩展,内建了对Java 8 CompletionStage的支持,以及对RxJava等其它响应式API的扩展点。

\\

参考JAX-RS 2.1规范,这次发布版本的目标包括用于POJO的注解(Annotation)以及可灵活使用的API,这些API提供了对通用HTTP使用模式和WebDAVAtom Publishing Protocol等应用的高层支持,支持多种HTTP实体内容类型、Servlet容器和JAX-WS提供者,并将提供Web资源类中对Java EE特性和组件的支持。

\\

在InfoQ对Pericas-Geertsen的采访中,他详细介绍了SSE:

\\
\

SSE资源中注入了一种称为SseEventSink的特定类型,提供文本流和事件流。SSE客户使用SseEventSource从连接中读取事件。

\\

该机制使用了长连接和广播,提供的性能要比轮询和资源密集短连接更优。

\
\\

下面的代码段展示了SSE的用法:

\\

服务器端:

\\
\@GET\@Produces(MediaType.SERVER_SENT_EVENTS)\public void getMessageQueue(@Context Sse sse, @Context SseEventSink eventSink) {\    // 一旦客户订购事件流,就激活资源方法。\    // 这意味着事件更像是从不同的场景中发出,例如线程、事件处理器等。\    // 资源方法通常实现为存储eventSink实例,应用逻辑将在事件应被发送到客户时检索事件。\    // 发送事件:\    eventSink.send(sse.newEvent(\"event1\"));\}\
\\

客户端:

\\
\WebTarget target = ClientBuilder.newClient().target(\"server-sent-events\");\SseEventSource eventSource = SseEventSource.target(target).build();\// EventSource#register(Consumer)\// 经注册的事件处理器将打印出所接收到的消息。\eventSource.register(System.out::println);\// 向事件流订阅。\eventSource.open();\
\\

Pericas-Geertsen补充了一下几点:

\\
  • \

    JAX-RS 2.1完全向后兼容前期版本。

    \ \\
  • \

    新特性很好地集成了现有的JAX-RS概念。例如,仅需在客户调用中注入一个方法调用,就可以将处理方式由同步转向响应式。

    \ \\
  • \

    SSE依赖基于流HTTP的连接,是现有API的自然扩展。

    \ \

鉴于该API广泛地使用了注解机制和Lambda表达式,因此它支持Java SE 8及以后版本所开发的应用。

\\

查看英文原文: Java API for RESTful Web Services 2.1 Released

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值