`
zzc1684
  • 浏览: 1231033 次
  • 性别: Icon_minigender_1
  • 来自: 广州
文章分类
社区版块
存档分类
最新评论

JAX-RS入门 九: 内容约定(1)

阅读更多

通常一个SOA的应用都需要足够的灵活,以便于各种不同的客户端或平台进行集成与交互。 RESTful 服务在这方面相当有优势,因为大部分的程序语言都能够与HTTP协议间相互通信。

 

不过这还不够,为了高效的运行,不同的用户可能有不同的需求。例如Java用户端更多的希望他们的数据是xml格式的;Ajax用户端则更喜欢JSON格式;Ruby用户需要想要YAML格式。另外,有时他们还希望这些数据是经过的国际化的,这样他们可以提供翻译好的信息给不同的,例如英语、中文、日文、西班牙文或法文用户。最后,随着RESTful应用的不断发展,老用户也需要一个简单的方法来与新版本的服务进行交互。

 

HTTP协议有很多手段可以帮助解决这些集成问题。一个最强大的功能就是用户可以告诉服务器他们希望的返回格式,客户端和服务器可以约定好消息体的内容格式,例如:它是怎么编码的;它需要返回哪种语言格式等。这种协议被称为HTTP Content Negotiation(HTTP内容约定),简称conneg。 这节主要介绍conneg是怎么工作的,JAX-RS怎么支持它以及在你的应用中协调这些特性有多重要。

 

一、Conneg

 

* Media Type

  

当请求服务端信息时,用户可以指定他们希望的返回的Media Type,这是通过客户端设置的Accept 请求头来实现的,其中Accept的主体部分以逗号分隔。例如:

Java代码 复制代码 收藏代码
  1. GET http://example.com/stuff   
  2. Accept: application/xml, application/json  

上例中,客户端要求服务端以XML或JSON的格式返回对/stuff的请求。如果服务器不能提供期望的返回格式,则会得到一个406(Not Acceptable)响应码;否则服务器端选择其中的一种返回格式,将响应结果发回给客户端。

 

在Accept中还支持通配符和Media Type属性,例如:

Java代码 复制代码 收藏代码
  1. GET http://example.com/stuff   
  2. Accept: text/*, text/html;level=1  

text/*表示任何text格式。

 

* Media Type优先级

 

HTTP协议有隐式和显式选择返回的Media Type规则。

 

        > 隐式规则

隐式规则就是越具体的Media Type总是优先于越宽泛的规则,例如:

 

Java代码 复制代码 收藏代码
  1. GET http://example.com/stuff   
  2. Accept: text/*, text/html;level=1, */*, application/xml  

服务器端会假设客户端总是想要一个具体的,而不是宽泛的响应类型,因此以上Accept的Media Types的顺序如下:

Java代码 复制代码 收藏代码
  1. 1. text/html;level=1  
  2. 2. application/xml   
  3. 3. text/*  
  4. 4. */*  

因为text/html;level=1最具体的,因为排第一;然后是application/xml,因为它没有任何属性定义;然后是text/*和*/*都是宽泛定义,但是相对*/*来说,text/*更具体一些。

 

        > 显式规则

客户端也可以通过使用MIME type的q属性来指定优先顺序,q的值域为0.0到1.0,如果未指定,则缺省值被假设为1.0。例如:

 

 

Java代码 复制代码 收藏代码
  1. GET http://example.com/stuff   
  2. Accept: text/*;q=0.9, */*;q=0.1, audio/mpeg, application/xml;q=0.5  

如上的顺序为:

Java代码 复制代码 收藏代码
  1. 1. audio/mpeg   
  2. 2. text/*  
  3. 3. application/xml  
  4. 4. */*    

二、语言约定

 

客户端使用Accept-Language头来指定他们需要接收哪个语种,例如:

Java代码 复制代码 收藏代码
  1. GET http://example.com/stuff   
  2. Accept-Language: en-us, es, fr   

这里用户希望响应内容为英语、西班牙语或法语。Accept-Lauguage头使用编码格式来指定,以两个字母代码表示某种语言,其中这些代码与语言的映射在ISO-639*标准中定义;除此之处,还可以增加两个字母更具体的指定是哪个国家的那种语言,例如en-US表示美国英语。

 

另外Accept-Language头也支持q参数来指定优先级,例如:

Java代码 复制代码 收藏代码
  1. GET http://example.com/stuff   
  2. Accept-Language: fr;q=1.0, es;q=1.0, en=0.1  

对于服务器端的响应,则使用: Content-Language 。来告诉客户端返回内容的语种。 

 

 

三、压缩约定

 

为了节省带宽,HTTP协议也支持内容压缩。最通用的压缩算法就是GZIP。客户端可以指定Accept-Encoding头来指定他们支持哪种压缩算法,例如:

 

Java代码 复制代码 收藏代码
  1. GET http://example.com/stuff   
  2. Accept-Encoding: gzip, deflate  

这里客户端说他希望响应内容是以gzip压缩或者干脆是不压缩的。

 

Accept-Encoding也支持q参数,来指定选择的优先级:

 

Java代码 复制代码 收藏代码
  1. GET http://example.com/stuff   
  2. Accept-Encoding: gzip;q=1.0, compress;0.5; deflate;q=0.1    

对于服务器端的响应,则使用: Content-Encoding 。来告诉客户端返回内容的压缩算法。

分享到:
评论

相关推荐

    jax-rs jax-ws所需包,亲测可用

    1. **JAX-RS**(Java API for RESTful Web Services)是Java平台上的REST(Representational State Transfer)风格Web服务的标准。REST是一种轻量级的架构风格,它基于HTTP协议,利用URL来定位资源,使用HTTP方法...

    JAX-RS入门jar包集合

    本资源“JAX-RS入门jar包集合”包含了开始学习和使用JAX-RS所需的基本库文件,这些jar包将帮助开发者快速搭建REST服务环境。下面我们将详细讲解JAX-RS的核心概念和关键组件,以及如何利用这些jar包进行实际开发。 1...

    [Jax-RS] RESTful Java 开发 (Jax-RS 实现) (英文版)

    [奥莱理] RESTful Java 开发 (Jax-RS 实现) (英文版) [奥莱理] RESTful Java with Jax-RS (E-Book) ☆ 图书概要:☆ Learn how to design and develop distributed web services in Java using RESTful ...

    [Jax-RS] RESTful Java 开发 (Jax-RS 2.0 实现) (英文版)

    The RESTEasy workbook that follows provides step-by-step instructions for installing, configuring, and running several working JAX-RS examples, using the JBoss RESTEasy implementation of JAX-RS 2.0. ...

    Jax-RS所需要的依赖jar

    1. **JAX-RS标准**:JAX-RS是JSR 339的一部分,它定义了一组用于构建RESTful Web服务的API。通过注解如`@Path`、`@GET`、`@POST`等,开发者可以直接在Java类和方法上声明HTTP操作和资源路径。 2. **服务器容器**:...

    JAX-WS API, JAX-RS API

    综上所述,JAX-WS和JAX-RS都是Java平台中处理Web服务的重要工具,但它们的侧重点不同。JAX-WS专注于SOAP协议的Web服务,而JAX-RS则面向RESTful风格的API设计。了解并熟练掌握这两个API,对于Java开发者来说,意味着...

    JAX-RS包(内含1.0和1.4)

    JAX-RS,全称Java API for RESTful Web Services,是Java平台上的一个标准,用于构建RESTful风格的Web服务。REST(Representational State Transfer)是一种轻量级、基于HTTP协议的设计模式,常用于实现分布式系统中...

    一个包含jax-ws和jax-rs的例子(含服务端和客户端)

    标题中的“一个包含jax-ws和jax-rs的例子(含服务端和客户端)”是指这是一个示例项目,它演示了如何使用Java API for XML Web Services (JAX-WS)和Java API for RESTful Web Services (JAX-RS)来创建和消费Web服务。...

    jackson-jaxrs-json-provider-2.7.8-API文档-中文版.zip

    赠送jar包:jackson-jaxrs-json-provider-2.7.8.jar; 赠送原API文档:jackson-jaxrs-json-provider-2.7.8-javadoc.jar; 赠送源代码:jackson-jaxrs-json-provider-2.7.8-sources.jar; 赠送Maven依赖信息文件:...

    JAX-RS Extension

    1. **JAX-RS基础**:JAX-RS是Java标准JSR 311和JSR 339的一部分,用于简化创建RESTful Web服务。它通过注解如`@Path`, `@GET`, `@POST`, `@PUT`, `@DELETE`等,使得开发者可以直接在Java方法上声明HTTP操作。 2. **...

    SpringMVC精品资源--JAX-RS & SpringMVC supported maven buil.zip

    SpringMVC和JAX-RS是两种在Java世界中广泛使用的Web开发框架,它们都用于构建RESTful服务,但有着不同的设计哲学和技术实现。这个压缩包"SpringMVC精品资源--JAX-RS & SpringMVC supported maven build.zip"显然是一...

    jax-rs开发实例(bookkeeping)

    **JAX-RS 开发实例:Bookkeeping** JAX-RS,全称为Java API for RESTful Web Services,是Java平台上的一个标准,用于构建RESTful Web服务。它为开发人员提供了一种简单、直观的方式来创建Web服务,这些服务可以...

    JAX-RS-demo:学术项目的 JAX-RS 演示

    1. **源代码**:包含服务端点类(Endpoint)和可能的数据模型类(Entities),使用 JAX-RS 注解进行标注。 2. **配置文件**:如 `web.xml` 或 `application.properties`,配置服务器和 JAX-RS 组件。 3. **Maven 或 ...

    JAX-RS+spring

    1. **集成方式**: 通常通过Spring的Servlet容器如Tomcat或Jetty来部署JAX-RS应用,Spring负责应用的上下文管理和依赖注入,JAX-RS处理REST接口。 2. **Spring REST**: 使用Spring MVC的`@RestController`注解创建...

    java_webservice_JAX-RS.zip_cxf_jax_jax-rs_spring cxf

    1. 创建JAX-RS服务类:使用JAX-RS注解定义资源和操作。 2. 配置Spring:定义服务bean,并设置其在Spring上下文中的行为。 3. 配置CXF:在web.xml中添加CXF Servlet或监听器,指定Spring配置文件。 4. 打包和部署:将...

    jax-rs 2.1规范最终版-英文

    JAX-RS(Java™ API for RESTful Web Services)是Java平台上用于开发基于REST架构风格的Web服务的API。它是Java EE(Java Platform, Enterprise Edition)的一部分,也作为独立的JAX-RS Reference Implementation ...

    Spring MVC与JAX-RS比较与分析

    JAX-RS(JSR 311)指的是Java API for RESTful Web Services,Roy Fielding也参与了JAX-RS的制订,他在自己的博士论文中定义了REST。对于那些想要构建RESTful Web Services的开发者来说,JAX-RS给出了不同于JAX-WS...

    jackson-jaxrs-providers:包含用于JSON,XML,YAML,Smile,CBOR格式的基于Jackson的JAX-RS提供程序的多模块项目

    概述这是一个多模块项目,包含用于以下数据格式的基于Jackson的JAX-RS提供程序:(二进制JSON) (另一种二进制JSON) 提供程序实现特定数据格式的JAX-RS MessageBodyReader和MessageBodyWriter处理程序。...

    RESTful Java with JAX-RS 2.0

    《RESTful Java with JAX-RS 2.0》是一本专注于Java语言在构建RESTful服务方面的专著。作者Bill Burke以其在Java技术方面的深厚底蕴和对RESTful架构的深刻理解,引领读者深入理解并掌握JAX-RS 2.0标准。 书中首先...

Global site tag (gtag.js) - Google Analytics