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

JAX-RS入门 四: 注入

阅读更多

一、Annotations

  • @javax.ws.rs.PathParam: 从URI模板参数中提取数据
  • @javax.ws.rs.MatrixParam:从URI中提取Matrix参数
  • @javax.ws.rs.QueryParam:从URI中提取查询参数
  • @javax.ws.rs.FormParam:提取Post Form参数
  • @javax.ws.rs.HeaderParam:提取HTTP请求头信息
  • @javax.ws.rs.CookieParam:提取客户设置的cookie的信息
  • @javax.ws.rs.core.Context:通用的注入annotation,允许注入各种帮助或者信息对象

通常这些注释用在服务方法上,当JAX-RS收到一个请求会,就会去查找相应的服务方法,然后把方法需要的信息注入。

 

如果是 “每个请求一个对象”的模式,你可以将这些annotation用在变量、set方法或者是构造方法上;如果是单态模式,则不允许将这些annotation用在变量、或者set方法上,因为对像会同时处理多个请求,如果将这些值用在变量或者set方法上,则多个请求会彼此冲突,陷入错误。

 

二、PathParam

Java代码 复制代码 收藏代码
  1. public class CustomerResource {   
  2.     ...   
  3.     @Path("{id}")   
  4.     @GET  
  5.     @Produces("application/xml")   
  6.     public StreamingOutput getCustomer(@PathParam("id"int id) {   
  7.         ...   
  8.     }   
  9. }   

此处,取得{id}的值,并试图转换成一个int型的值。

 

可以同时使用多个PathParam:

Java代码 复制代码 收藏代码
  1. @Path("/customers")   
  2. public class CustomerResource {   
  3.     ...   
  4.     @Path("{first}-{last}")   
  5.     @GET  
  6.     @Produces("application/xml")   
  7.     public StreamingOutput getCustomer(@PathParam("first") String firstName,   
  8.         @PathParam("last") String lastName) {   
  9.         ...   
  10.     }   
  11. }  

PathParam的范围:总是引用最接近的PathParam的值,例如:

Java代码 复制代码 收藏代码
  1. @Path("/customers/{id}")   
  2. public class CustomerResource {   
  3.     @Path("/address/{id}")   
  4.     @Produces("text/plain")   
  5.     @GET  
  6.     public String getAddress(@PathParam("id") String addressId) {...}   
  7. }  

例如HTTP请求为:GET /customers/123/address/456 , 则 addressId 的值为456.

 

注入PathSegment

PathParam除了可以注入Path参数,也可以注入一个javax.ws.rs.core.PathSegment实便;PathSegment是一个特定Path片段的抽象,如下:

Java代码 复制代码 收藏代码
  1. package javax.ws.rs.core;   
  2. public interface PathSegment {   
  3.     String getPath();   //具体的URI的path片段值,去除了所有的matrix参数   
  4.     MultivaluedMap<String, String> getMatrixParameters();  //该path片段拥有的所有的matrix值   
  5. }  

然后如下使用:

Java代码 复制代码 收藏代码
  1. @Path("/cars/{make}")   
  2. public class CarResource {   
  3.     @GET  
  4.     @Path("/{model}/{year}")   
  5.     @Produces("image/jpeg")   
  6.     public Jpeg getPicture(@PathParam("make") String make,   
  7.     @PathParam("model") PathSegment car,   
  8.     @PathParam("year") String year) {   
  9.         String carColor = car.getMatrixParameters().getFirst("color");   
  10.         ...   
  11.     }   
  12. }  

例如:GET /cars/mercedes/e55;color=black/2006。则 make是mercedes;model是e55;year是2006;color是black。

  

注入多个PathSegment

如果对对应有Path含有多个path片段,则需要注入多个PathSegments类,例如:

Java代码 复制代码 收藏代码
  1. @Path("/cars/{make}")   
  2. public class CarResource {   
  3.     @GET  
  4.     @Path("/{model : .+}/year/{year}")   
  5.     @Produces("image/jpeg")   
  6.     public Jpeg getPicture(@PathParam("make") String make,   
  7.         @PathParam("model") List<PathSegment> car,   
  8.         @PathParam("year") String year) {   
  9.     }   
  10. }  

其中请求可能是:GET /cars/mercedes/e55/amg/year/2006。这里model对应的path片段为:/e55/amg。所以car变量中含有两个PathSegment对象。

 

用代码获取URI的信息

有时候可能想通过程序的方式获取URI中的信息,而不使用PathParam注释。这里我们需要通过接口javax.ws.rs.core.UriInfo接口去获取这些信息,UriInfo接口定义如下:

Java代码 复制代码 收藏代码
  1. public interface UriInfo {   
  2.     public String getPath();  //返回匹配的相对uri路径   
  3.     public String getPath(boolean decode); //返回解码后的相对uri路径   
  4.     public List<PathSegment> getPathSegments();  //返回path片段   
  5.     public List<PathSegment> getPathSegments(boolean decode); //返回解码后的path片段   
  6.     public MultivaluedMap<String, String> getPathParameters(); //返回PathParam表   
  7.     public MultivaluedMap<String, String> getPathParameters(boolean decode); //同上   
  8.     ...   
  9. }  

要获取UriInfo对象,就需要用到@javax.ws.rs.core.Context注释了。例如:

Java代码 复制代码 收藏代码
  1. @Path("/cars/{make}")   
  2. public class CarResource {   
  3.     @GET  
  4.     @Path("/{model}/{year}")   
  5.     @Produces("image/jpeg")   
  6.     public Jpeg getPicture(@Context UriInfo info) {   
  7.         String make = info.getPathParameters().getFirst("make");   
  8.         PathSegment model = info.getPathSegments().get(1);   
  9.         String color = model.getMatrixParameters().getFirst("color");   
  10.         ...   
  11.     }   
  12. }  

 

三、MatrixParam

 

除了上面介绍的使用PathSegment去获取MatrixParam值外,我们也可以直接使用@MatrixParam去获取值,这样来得更直接、简洁,例如:

Java代码 复制代码 收藏代码
  1. @Path("/{make}")   
  2. public class CarResource {   
  3.     @GET  
  4.     @Path("/{model}/{year}")   
  5.     @Produces("image/jpeg")   
  6.     public Jpeg getPicture(@PathParam("make") String make,   
  7.         @PathParam("model") String model,   
  8.         @MatrixParam("color") String color) {   
  9.         ...   
  10.     }   
  11. }  

不过如果Path中含有多个同名的MatrixParam,则还是需要使用PathSegment来获取,例如:GET /mercedes/e55;color=black/2006/interior;color=tan

 

四、@QueryParam

很显然,QueryParam用来获取查询参数,对于 GET /customers?start=0&size=10 ,例如:

Java代码 复制代码 收藏代码
  1. @Path("/customers")   
  2. public class CustomerResource {   
  3.     @GET  
  4.     @Produces("application/xml")   
  5.     public String getCustomers(@QueryParam("start"int start,   
  6.         @QueryParam("size"int size) {   
  7.         ...   
  8.     }   
  9. }  

这里start为0,size为10.

同上面的PathParam,也可以用UriInfo去获取QueryParam,例如:

Java代码 复制代码 收藏代码
  1. @Path("/customers")   
  2. public class CustomerResource {   
  3.     @GET  
  4.     @Produces("application/xml")   
  5.     public String getCustomers(@Context UriInfo info) {   
  6.         String start = info.getQueryParameters().getFirst("start");   
  7.         String size = info.getQueryParameters().getFirst("size");   
  8.         ...   
  9.     }   
  10. }  

 

五、@FormParam

 

很自然,FormParam用于提取POST请求中的Form参数,其中Content-Type被假设为application/x-www-formurlencoded。例如有以下Form请求

 

Html代码 复制代码 收藏代码
  1. <FORM action="http://example.com/customers" method="post">  
  2.     <P>  
  3.         First name: <INPUT type="text" name="firstname"><BR>  
  4.         Last name: <INPUT type="text" name="lastname"><BR>  
  5.         <INPUT type="submit" value="Send">  
  6.     </P>  
  7. </FORM>  

可以如下取值:

Java代码 复制代码 收藏代码
  1. @Path("/customers")   
  2. public class CustomerResource {   
  3.     @POST  
  4.     public void createCustomer(@FormParam("firstname") String first,   
  5.         @FormParam("lastname") String last) {   
  6.             ...   
  7.     }   
  8. }  

 

六、HeaderParam

很直接,用来提取HTTP Header值的。例如:

Java代码 复制代码 收藏代码
  1. @Path("/myservice")   
  2. public class MyService {   
  3.     @GET  
  4.     @Produces("text/html")   
  5.     public String get(@HeaderParam("Referer") String referer) {   
  6.         ...   
  7.     }   
  8. }  

 

如果想提取所有的header值,那就需要用到javax.ws.rs.core.HttpHeaders接口了:

 

Java代码 复制代码 收藏代码
  1. public interface HttpHeaders {   
  2. public List<String> getRequestHeader(String name);   
  3.     public MultivaluedMap<String, String> getRequestHeaders();   
  4.     ...   
  5. }  

例如方法同上面的PathSegment,也是用context去获取,例如:

Java代码 复制代码 收藏代码
  1. @Path("/myservice")   
  2. public class MyService {   
  3.     @GET  
  4.     @Produces("text/html")   
  5.     public String get(@Context HttpHeaders headers) {   
  6.         String referer = headers.getRequestHeader("Referer").get(0);   
  7.         for (String header : headers.getRequestHeaders().keySet())   
  8.         {   
  9.             System.out.println("This header was set: " + header);   
  10.         }   
  11.         ...   
  12.     }   
  13. }  

七、@CookieParam

提取cookie信息,例如:

Java代码 复制代码 收藏代码
  1. @Path("/myservice")   
  2. public class MyService {   
  3.     @GET  
  4.     @Produces("text/html")   
  5.     public String get(@CookieParam("customerId"int custId) {   
  6.         ...   
  7.     }   
  8. }  

这里注入了的是一个cookie的值,如果想取得更多的信息,而不公公是基本值,则可以直接注入javax.ws.rs.core.Cookie对象,例如:

Java代码 复制代码 收藏代码
  1. @Path("/myservice")   
  2. public class MyService {   
  3.     @GET  
  4.     @Produces("text/html")   
  5.     public String get(@CookieParam("customerId") Cookie custId) {   
  6.         ...   
  7.     }   
  8. }   

Cookie类具有一些其他的方法可以用来获取更多信息,例如:

Java代码 复制代码 收藏代码
  1. package javax.ws.rs.core;   
  2. public class Cookie   
  3. {   
  4.     public String getName() {...}   
  5.     public String getValue() {...}   
  6.     public int getVersion() {...}   
  7.     public String getDomain() {...}   
  8.     public String getPath() {...}   
  9.     ...   
  10. }  

也可以用javax.ws.rs.core.HttpHeaders获取所有的cookie:

Java代码 复制代码 收藏代码
  1. public interface HttpHeaders {   
  2.     ...   
  3.     public Map<String, Cookie> getCookies();   
  4. }  
Java代码 复制代码 收藏代码
  1. @Path("/myservice")   
  2. public class MyService {   
  3.     @GET  
  4.     @Produces("text/html")   
  5.     public String get(@Context HttpHeaders headers) {   
  6.         for (String name : headers.getCookies().keySet())   
  7.         {   
  8.             Cookie cookie = headers.getCookies().get(name);   
  9.             System.out.println("Cookie: " +   
  10.                 name + "=" + cookie.getValue());   
  11.         }   
  12.         ...   
  13.     }   
  14. }  
分享到:
评论

相关推荐

    JAX-RS入门jar包集合

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

    apache-cxf-3.1.6

    此外,它还支持JAX-RS(Java API for RESTful Web Services)和JAX-WS(Java API for XML Web Services),使得开发RESTful服务和SOAP服务变得简单。 8. **安全性**: CXF提供了多种安全机制,如基本认证、OAuth、...

    hello-world-apis:API API de grafos的世界您好

    通过深入学习和实践这些知识点,开发者可以创建高效、可靠且易于维护的API,无论是在"hello-world-apis"这样的入门项目还是实际的大型企业级应用中。在实际操作中,理解HTTP协议、熟悉Java编程、掌握图形理论以及对...

    jersey document

    这部分深入探讨了JAX-RS规范在Jersey框架中的应用,包括根资源类、HTTP方法、资源类的生命周期、注入规则、使用@Context注解以及程序化资源模型等概念。详细解释了如何在Jersey中使用各种注解如@Path、@GET、@PUT、@...

    camel-manual-2.10.4.pdf

    - Apache CXF:一个智能的Web服务套件(包括JAX-WS和JAX-RS)。 - Apache Karaf:一个小型的基于OSGi的运行时环境,其中可以部署容器代理的应用程序。 - Apache MINA:一个高性能的NIO驱动的网络框架。 Camel的核心...

    Jersey User Guild

    Jersey 是一个开源的 JAX-RS (Java API for RESTful Web Services) 实现,用于构建 RESTful Web 服务和微服务。它由 Apache 软件基金会提供支持,是 Java 社区中用于 RESTful 服务开发的主要工具之一。Jersey 用户...

    JavaEE-7-Samples:所有 Java EE6 和 7 示例

    Java EE 7增强了JAX-RS 2.0,包括支持超媒体链接和更强大的异常处理。 通过"JavaEE-7-Samples"项目,开发者可以学习到如何在实际环境中应用这些技术,从而提升他们的Java EE开发技能。每个示例都会包含详细的代码和...

    cxf webserice 开发指南

    它提供了强大的支持,包括对JAX-WS和JAX-RS标准的实现,以及丰富的工具集,帮助开发者从Java类生成WSDL,反之亦然。本文将引导你逐步了解如何在项目中集成CXF,进行Web服务的开发。 **一、CXF WebService 准备工作*...

    Jersey 2.25.1 User Guide

    - **5.2 易用性和 JAX-RS 资源重用**:讨论了 Jersey 客户端 API 如何简化开发流程,以及如何重用现有的 JAX-RS 资源。 - **5.3 客户端 API 概览**: - **开始使用客户端 API**:提供了入门教程,帮助用户快速...

    Your First Cup An Introduction to the Java EE6 Platform.pdf

    - **简化开发:**通过引入新的API和技术,如JSR 311 (JAX-RS) 和JSR 299 (CDI),极大地简化了开发流程。 - **提高效率:**新的开发工具和集成环境(IDE)支持,例如Eclipse和NetBeans,提高了开发效率。 - **增强...

    Java_快速入门演示了JBoss EAP Jakarta EE 10和一些其他技术,它们提供了小的特定工作示例,可以.zip

    - **RESTful服务**:使用JAX-RS创建API并测试响应。 - **微服务**:可能包含如何将大型应用拆分为独立的服务。 `jboss-eap-quickstarts_8.0.x.zip`文件很可能是JBoss EAP 8.0的快速启动项目集合,这些项目提供了预...

    Jersey2中文文档_高清版_带目录可跳转

    2. **JAX-RS 2.0 支持**:Jersey2 全面支持 JAX-RS 2.0 规范,提供了一组注解,如 `@Path`、`@GET`、`@POST` 等,用于定义资源和处理方法。 3. **过滤器与拦截器**:Jersey2 提供了过滤器(Filter)和拦截器...

    resteasy guide

    RESTEasy是JAX-RS规范的一个开源实现,它为Java开发者提供了一种简单而强大的方式来创建RESTful Web服务。RESTEasy不仅仅是一个框架,它还包含了一系列的工具和特性,帮助开发者在不同的环境中(如独立应用服务器或...

    CXF-WebService-开发指南、技术文档.docx

    它提供了强大的服务实现和客户端调用能力,支持多种协议和规范,如JAX-WS、JAX-RS等。本指南将详细介绍如何使用CXF进行Web服务开发。 **一、CXF WebService 准备工作** 1. **官方网址**:[http://cxf.apache.org/]...

    guice-jersey:Guice模块,用于使用Jersey启动基于Jetty的休息服务器

    如果您使用Guice作为依赖项注入框架,并且想将自己的类注入到您创建的JAX-RS类中(例如“资源”和“过滤器”),则需要弥合这两个DI框架之间的鸿沟。 该模块旨在通过启动基于Jetty的Jersey服务器并初始化HK2与Guice...

    Beginning_Java_EE_6_Platform_with_GlassFish

    《初识Java EE 6平台与GlassFish》是一本针对Java企业级应用开发的入门教程,旨在帮助读者理解和掌握Java EE 6平台的核心概念和技术,同时结合GlassFish服务器的使用,提供实际操作的经验。这本书是Java J2EE(Java ...

    CXF3.0.2+Spring3.2.14 WebService入门实例四

    【CXF3.0.2+Spring3.2.14 WebService入门实例四】的知识点解析 在本文中,我们将深入探讨如何使用Apache CXF 3.0.2版本和Spring 3.2.14框架来创建一个基于WebService的文件传输应用。Apache CXF是一个流行的开源...

    CXF 入门示例

    它提供了丰富的功能,包括对JAX-WS和JAX-RS的支持,允许开发者轻松创建服务提供者和服务消费者。CXF的核心设计是基于消息处理的,这使得它具有高度可扩展性。 **1. Bus架构** CXF的Bus是其核心组件,相当于Spring的...

    cxf入门

    - CXF支持JAX-RS(Java API for RESTful Web Services),提供REST服务的创建和消费能力。 7. **安全**: - CXF支持各种安全机制,如基本认证、HTTPS、WS-Security等,确保Web服务的安全通信。 8. **异常处理**...

    CXF 一个完整的webService(整合客户端和服务端)

    CXF通过JAX-RS(Java API for RESTful Web Services)实现REST服务,允许开发者用简单的注解定义资源和操作。 **6. CXF与其他技术的整合** CXF可与其他Java EE技术如Spring、Hibernate等无缝集成,提供更强大的...

Global site tag (gtag.js) - Google Analytics