欢迎访问悦橙教程(wld5.com),关注java教程。悦橙教程  java问答|  每日更新
页面导航 : > > 文章正文

GlassFish 4 中EclipseLink MOXY实现REST应用简介(1)

来源: javaer 分享于  点击 11224 次 点评:204

GlassFish 4 中EclipseLink MOXY实现REST应用简介(1)


最近,随着JAVA EE 7 标准的最终落地,其中Oracle 还发布了GlassFish 4服务器,它可以说是JAVA EE 7标准的一种参考实现。 其中,Eclipse旗下的EclipseLink开源项目向JAVE EE 7中贡献了不少力量,其中包括JPA 2.1 (JSR-338)的实现,另外一个贡献是本文向大家介绍的EclipseLink MOXy项目,它是JAVE EE 7JAX-RS(REST标准)的一个默认的JSON Provider

首先简单介绍下Eclipse旗下的EclipseLink开源项目,它主要用来实现快速将JAVA中的对象转化为各种类型的XML,该项目主要有如下的特性:

  • 支持JAXB中最多的注解
  • 同时支持XML和JSON
  • 支持最新的JPA 2.1

对JPA-RS的增强支持

 MOXY有十分强大的将各类JAVA对象 序列化为XML以及XML反序列化为JAVA对象的能力。这在REST架构的应用中,MOXY可以用来实现JAX-RS标准中的各种转换,下面以一个REST的例子进行讲解。如果读者对REST和JAX-RS标准有不清楚的地方,请参考相关的资料。

我们设计一个最简单的Hello World的REST Webservice。其中Customer对象是一个简单的POJO对象,代码如下:

  1. package org.example.service; 
  2.  
  3. import javax.ejb.*; 
  4. import javax.ws.rs.*; 
  5. import javax.ws.rs.core.MediaType; 
  6. import org.example.model.*; 
  7.  
  8. @Stateless 
  9. @LocalBean 
  10. @Path("/customers"
  11. public class CustomerService { 
  12.  
  13.     @GET 
  14.     @Produces({ 
  15.         MediaType.APPLICATION_XML, 
  16.         MediaType.APPLICATION_JSON 
  17.     }) 
  18.     @Path("{id}"
  19.     public Customer read(@PathParam("id"int id) { 
  20.         Customer customer = new Customer(); 
  21.         customer.setId(id); 
  22.         customer.setName("Jane Doe"); 
  23.  
  24.         PhoneNumber pn = new PhoneNumber(); 
  25.         pn.setType("work"); 
  26.         pn.setValue("5551111"); 
  27.         customer.getPhoneNumbers().add(pn); 
  28.  
  29.         return customer; 
  30.      } 
  31.  

可以看到,Customer对象中有一个PhoneNumber的表示电话号码的Pojo。代码中的注解都是遵守JAX-RS标准的REST相关的注解。其中,用注解

@ MediaType.APPLICATION_XML@ MediaType.APPLICATION_JSON,分别指出该REST会同时以XMLJSON的形式对外发布。而在JAX-RS标准中,用如下的方式,就可以实现REST的对外发布部署:

  1.  package org.example.service; 
  2.  
  3. import javax.ws.rs.ApplicationPath; 
  4. import javax.ws.rs.core.Application; 
  5.  
  6. @ApplicationPath("rest/*"
  7. public class CustomerApplication  extends Application { 
  8.  

其中,@ApplicationPath 注解指定所有服务的相对基址,如果为空字符串,则直接使用上下文根路径。上面表示这个REST服务将以如http://localhost/rest/xxx的形式对外发布,应该的根为rest。
  接下来我们具体看Customer这个POJO,代码如下:

  1. package org.example.model; 
  2.  
  3. import java.util.*; 
  4. import javax.xml.bind.annotation.*; 
  5.  
  6. @XmlRootElement 
  7. public class Customer { 
  8.  
  9.     private int id; 
  10.     private String name; 
  11.     private List<PhoneNumber> phoneNumbers = new ArrayList<PhoneNumber>(); 
  12.  
  13.     public int getId() { 
  14.         return id; 
  15.     } 
  16.  
  17.     public void setId(int id) { 
  18.         this.id = id; 
  19.     } 
  20.  
  21.     public String getName() { 
  22.         return name; 
  23.     } 
  24.  
  25.     public void setName(String name) { 
  26.         this.name = name; 
  27.     } 
  28.  
  29.     @XmlElementWrapper 
  30.     @XmlElement(name="phoneNumber"
  31.     public List<PhoneNumber> getPhoneNumbers() { 
  32.         return phoneNumbers; 
  33.     } 
  34.  

在这个Customer对象中,其中保持了对另外一个对象phoneNumber的引用。使用@XmlElementWrapper,其目的是为了在XML中通过单独设置名为phoneNumber的别名标签去
更清晰的输出。
  接下来请看PhoneNumber类,代码如下:

  1. package org.example.model; 
  2.  
  3. import javax.xml.bind.annotation.*; 
  4.  
  5. public class PhoneNumber { 
  6.  
  7.     private String type; 
  8.     private String value; 
  9.  
  10.     @XmlAttribute 
  11.     public String getType() { 
  12.         return type; 
  13.     } 
  14.  
  15.     public void setType(String type) { 
  16.         this.type = type; 
  17.     } 
  18.  
  19.     @XmlValue 
  20.     public String getValue() { 
  21.         return value; 
  22.     } 
  23.  
  24.     public void setValue(String value) { 
  25.         this.value = value; 
  26.     } 
  27.  

注意,其中使用了注解@XmlAttribute,将type设置为转换后XML中的一个属性,而@XmlValue则将字段value直接序列为值,即如下的样子:


相关栏目:

用户点评