`
lifeba
  • 浏览: 13473 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

RESTLET开发实例(一)基于JAX-RS的REST服务

    博客分类:
  • JAVA
阅读更多

RESTLET介绍

Restlet项目为“建立REST概念与Java类之间的映射”提供了一个轻量级而全面的框架。它可用于实现任何种类的REST式系统,而不仅仅是REST式Web服务。


Restlet项目受到Servlet API、JSP(Java Server Pages)、HttpURLConnection及Struts等Web开发技术的影响。该项目的主要目标是:在提供同等功能的同时,尽量遵守Roy Fielding博士论文中所阐述的REST的目标。它的另一个主要目标是:提出一个既适于客户端应用又适于服务端的应用的、统一的Web视图。


Restlet的思想是:HTTP客户端与HTTP服务器之间的差别,对架构来说无所谓。一个软件应可以既充当Web客户端又充当Web服务器,而无须采用两套完全不同的APIs。

 

准备工作

1、Restlet提供了多个版本:Java SE、Java EE、android、Google AppEngine、Google Web Toolkit、Android。
这里我们下载jee版本。
restlet-jee-2.0.6.zip 下载地址:http://www.restlet.org/downloads/2.0/restlet-jee-2.0.6.zip

 

2、restlet-jee-2.0.6.zip解压到硬盘,这里以%RESTLET_HOME%表示为解压的文件目录。

 

一、基于JAX-RS的REST服务

JAX-RS (JSR-311) 是一种 Java API,可使 Java Restful 服务的开发变得迅速而轻松。这个 API 提供了一种基于注释的模型来描述分布式资源。注释被用来提供资源的位置、资源的表示和可移植的(pluggable)数据绑定架构。在本文中,学习如何使用 JAX-RS 在 Java EE 环境内实现 RESTful 服务架构的潜能。

 

1、新建java web project RestService工程

 

2、%RESTLET_HOME%\lib 复制到 \RestService\WebRoot\WEB-INF\lib 下,并加入工程引用。为了测试方便可以将全部的lib包加入进去。实
际上面,你可以根据实际需要只复制相应的包进去即可。下面的图片是我加入的相关的jar包:

 

 

org.restlet.jar这个是必须的,如果是用于JAX-RS发布rest的话,还需要这几个包:
javax.ws.rs.jar
javax.xml.bind.jar
org.json.jar
org.restlet.ext.jaxrs.jar
org.restlet.ext.json.jar
org.restlet.ext.servlet.jar

 

3、创建Student实体类,用于返回数据。Student使用JAXB绑定技术,自动解析为xml返回给客户端或浏览器。

JAXB是一套自动映射XML和Java实例的开发接口和工具。JAXB使XML更加方便的编译一个XML SCHEMA到一个或若干个JAVA CLASS。可以从
使用 JAXB 进行数据绑定  获得详细介绍。

@XmlRootElement(name=”Student”)
public class Student {
 
 private int id;
 private String name;
 private int sex;
 private int clsId;
 private int age;
 
 public int getId() {
  return id;
 }
 public void setId(int id) {
  this.id = id;
 }
 public String getName() {
  return name;
 }
 public void setName(String name) {
  this.name = name;
 }
 public int getSex() {
  return sex;
 }
 public void setSex(int sex) {
  this.sex = sex;
 }
 public int getClsId() {
  return clsId;
 }
 public void setClsId(int clsId) {
  this.clsId = clsId;
 }
 public int getAge() {
  return age;
 }
 public void setAge(int age) {
  this.age = age;
 }
}

4、Restlet架构主要是Application和Resource的概念。程序上可以定义多个Resource,一个Application可以管理多个Resource。

创建应用类:StudentApplication 继承了抽象类:javax.ws.rs.core.Application,并重载getClasses()方法。代码如下:

Set<Class<?>> rrcs = new HashSet<Class<?>>();
rrcs.add(StudentResource.class);

绑定了StudentResource。有多个资源可以在这里绑定。你可以有Course等其他更多资源,相应的可以定义为:CourseResource及Course,然后加入rrcs.add(CourseResource.class)。

创建资源类:StudentResource管理Student实体类

@Path(“student”)
public class StudentResource {
 
     @GET
     @Path(“{id}/xml”)
     @Produces(“application/xml”)
     public Student getStudentXml(@PathParam(“id”) int id) {
   return ResourceHelper.getDefaultStudent();
     }
}

其中:
@Path(“student”)执行了uri路径,student路径进来的都会调用StudentResource来处理。
@GET 说明了http的方法是get方法。
@Path(“{id}/xml”) 每个方法前都有对应path,用来申明对应uri路径。
@Produces(“application/xml”) 指定返回的数据格式为xml。
@PathParam(“id”) int id  接受传递进来的id值,其中id为 {id}定义的占位符要一致。
和上面类似,我们可以定义返回json格式方法,如下

@GET
@Path(“{id}/json”)
@Produces(“application/json”)
public Student getStudentJson(@PathParam(“id”) int id) {
  return ResourceHelper.findStudent(id);
}

其中:
@Produces(“application/json”)  指定返回的数据格式为json。

 

5、定义了相应的Resource和Application后,还要创建运行环境。RESTlet 架构为了更好的支持 JAX-RS 规范,定了 JaxRsApplication 类来初始化基于 JAX-RS 的 Web Service 运行环境。

 

创建运行类:RestJaxRsApplication  继承了类:org.restlet.ext.jaxrs.JaxRsApplication。构造方法代码如下:

public RestJaxRsApplication(Context context) {
 super(context);
 this.add(new StudentApplication());
}

将StudentApplication加入了运行环境中,如果有多个Application可以在此绑定。

 

二、发布和部署restlet服务

1、将Restlet服务部署到 Tomcat容器中

 

web.xml加入如下代码:

<context-param>
 <param-name>org.restlet.application</param-name>
 <param-value>ws.app.RestJaxRsApplication</param-value>
</context-param>

<servlet>
 <servlet-name>RestletServlet</servlet-name>
 <servlet-class>org.restlet.ext.servlet.ServerServlet</servlet-class>
</servlet>

<servlet-mapping>
 <servlet-name>RestletServlet</servlet-name>
 <url-pattern>/*</url-pattern>
</servlet-mapping>

启动tomcat没报错的话,说明你配置正常。

 

2、将Restlet服务当做单独的Java 程序进行部署

 

创建类 RestJaxRsServer,代码如下:

public static void main(String[] args) throws  Exception {
 Component component = new Component();
 component.getServers().add(Protocol.HTTP, 8085);        
 component.getDefaultHost().attach(new RestJaxRsApplication(null));
 component.start(); 
}

该类中创建一个新的 Http Server,添加监听端口8085。将RestJaxRsApplication加入到 Http Server 中。运行该代码,下图说明你启动成功。

 

 

三、测试Restlet服务

1、浏览器模式

 

访问xml数据 http://localhost:8085/RestService/student/1/xml

 

 

访问json数据 http://localhost:8085/RestService/student/1/json  提示下载数据,下载后打开数据内容为

 

{“name”:”Steven”,”id”:1,”age”:0,”sex”:1,”clsId”:201001}

 

 

如果是独立部署的话,直接访问:http://localhost:8085/student/1/xml 即可。

 

2、Restlet自带了客户端测试代码,目前提供了jee、webkit、android等版本,调用rest服务,非常方便。

 

新建Client类,代码如下:

//public static String url=”http://localhost:8085/“;
 
public static String url=”http://localhost:8085/RestService/“;

public static void testXml() {
 ClientResource client = new ClientResource(url+”student/1/xml”);
 try {
  System.out.println(client.get().getText());
 } catch (ResourceException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 } catch (IOException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 }
}

public static void testJson() {
 ClientResource client = new ClientResource(url+”student/1/json”);
 try {
  System.out.println(client.get().getText());
 } catch (ResourceException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 } catch (IOException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 }
}

通过junit测试代码分别输出:

 

 

 

四、实现对Rest服务的PUT,POST,DELETE方法。

到现在我们已经完成一个基本的Rest搭建,并且实现了GET方法。REST定义了4个基本方法:可以参见 REST架构概述

 

1、POST方法

 

在StudentResource中加入该方法,用于添加一个Student:

@POST
@Path(“add”)
public String addStudent(Representation entity) {
  Form form = new Form(entity);
  String name = form.getFirstValue(“name”);
  int clsId = Integer.parseInt(form.getFirstValue(“clsId”));
  int sex = Integer.parseInt(form.getFirstValue(“sex”));
  Student student = new Student();
  student.setClsId(clsId);
  student.setName(name);
  student.setSex(sex);
  ResourceHelper.maxId++;
  int id =  ResourceHelper.maxId;
  student.setId(id);
  return String.valueOf(ResourceHelper.addStudent(student));
}

@POST 说明这是个post方法调用,如果是用restlet客户端调用的话,调用client.post(form.getWebRepresentation())方法,如果是网页上面操作的话,就是一个标准的post方法。
Representation entity:Restlet中全部的接受和返回对象都Representation类的子类。将entity 封装为Form对象,就可以通过Form取得post过来的数据。


相应的客户端调用代码:

public static void testPost() {
ClientResource client = new ClientResource(url+”student/add”);
try {
 Form form = new Form();
 form.add(“name”, “lifeba”);
 form.add(“clsId”,”201001″);
 form.add(“sex”,”0″);
 String id = client.post(form.getWebRepresentation()).getText();
 System.out.println(id);
 
} catch (Exception e) {
 // TODO Auto-generated catch block
 e.printStackTrace();
}
}

将需要传递的参数封装为Form对象,然后通过post(form.getWebRepresentation())来调用服务端post方法,返回时添加成功的Student的id。


添加成功后,访问:http://localhost:8085/RestService/student/2/xml  如下图:

 

 

除了上面的通过restlet提供的客户端调用外,你也可以直接通过网页的post数据过来。

 

新建java web project RestServiceForm工程,添加add.jsp。

<form action=”/RestService/student/add” method=”post”>
     用户名:<input type=”text” name=”name”><br>
     班级:<input type=”text” name=”clsId”><br>
     性别:<input type=”text” name=”sex”><br>
     <input type=”submit” value=”提交”>
</form>

 

 

提交成功后:

 

 

测试新添加的student数据:

 

 

2、PUT方法

 

PUT方法用来更新一个Student对象,和上面的POST方法类似。需要注意的地方,如果是通过restlet客户端接口来调用的话,必须使用client.put(form.getWebRepresentation())方法。主要代码如下:

@PUT
@Path(“update”)
public String updateStudent(Representation entity) {
  Form form = new Form(entity);

  int id = Integer.parseInt(form.getFirstValue(“id”));
  Student student = ResourceHelper.findStudent(id);
 
  String name = form.getFirstValue(“name”);
  int clsId = Integer.parseInt(form.getFirstValue(“clsId”));
  int sex = Integer.parseInt(form.getFirstValue(“sex”));
 
  student.setClsId(clsId);
  student.setName(name);
  student.setSex(sex);
 
  return String.valueOf(ResourceHelper.updateStudent(student));
}

Restlet客户端调用代码,对id为1的student进行编辑。

public static void testUpdate() {
 ClientResource client = new ClientResource(url+”student/update”);
 try {
  Form form = new Form();
  form.add(“name”, “steven2″);
  form.add(“clsId”,”201002″);
  form.add(“sex”,”0″);
  form.add(“id”,”1″);
  String id = client.put(form.getWebRepresentation()).getText();
  System.out.println(id);
  
 } catch (Exception e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 }
}

执行后访问http://localhost:8085/RestService/student/1/xml

 

 

那么我们如何从网页中直接调用put接口呢?form只有get和post方法,并没有put和delete的对应方法。Restlet为我们提供了method指定操作的支持。要在form中执行同样的操作,只需加入method=put即可,可以通过url直接拼接,或者post中加入隐藏input。这里如果直接拼接URL来实现,代码如下:

<form action=”/RestService/student/update?method=put” method=”post”>
 用户ID:<input type=”text” name=”id” ><br>
 用户名:<input type=”text” name=”name”><br>
 班级:<input type=”text” name=”clsId”><br>
 性别:<input type=”text” name=”sex”><br>
 <input type=”submit” value=”提交”>
</form>

 

执行成功后可以看到student为1的数据已经成功修改:

 

 

3、DELETE方法

 

和PUT、POST方法一样,主要代码如下:

@DELETE
@Path(“delete/{id}”)
public String deleteStudent(@PathParam(“id”) int id) {
  int status = ResourceHelper.deleteStudent(id);
  return String.valueOf(status);
}

Restlet客户端调用代码,这里删除2次,第一次返回1,说明删除成功,第二次返回0,说明该student已经删除了,所以返回0,没有找到该Student。

public static void testDelete() {
ClientResource client = new ClientResource(url+”student/delete/1″);
 try {
  System.out.println(client.delete().getText());
  System.out.println(client.delete().getText());
 } catch (ResourceException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 } catch (IOException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 }
}

 

通过网页的删除和上面的put类似,这里就不再说明了。

 

好了,到这里已经实现了GET、PUT、POST、DELETE 四个rest的基本操作。其中要注意的是,通过GET、DELETE 来操作的话,如果是调用Restlet客户端,是不传递Representation entity的,直接通过uri的占位符来传递id来操作。REST调用接口通过标准的HTTP接口来实现,Restlet返回的标准的xml、json格式。实现了跨客户端的调用。Restlet提供了android,webkit客户端调用支持,使用起来更加方便。

 

五、相关工程资源下载

RestService工程

RestServiceForm工程

 

 

分享到:
评论
1 楼 song_in_china 2012-06-17  
折腾来折腾去就那么点东西,不过我觉得可以自己实现这个,没啥可讲的,觉得走自己定义的filter比这好一些

相关推荐

    JAX-RS Rest RestLet项目源码

    总的来说,"JAX-RS Rest RestLet项目源码"为学习者提供了一个很好的起点,让他们能够动手构建自己的REST服务,并理解RESTful架构的核心概念。通过这个项目,不仅可以学习到JAX-RS的API,还能熟悉RESTLet框架的特性,...

    JAX-RS之rest接口实例

    **JAX-RS与REST接口实例...总结,这个JAX-RS和REST的实例展示了如何通过Java实现RESTful Web服务,包括服务端的资源类定义、服务启动类以及客户端的调用。理解并掌握这些知识对于开发基于HTTP的分布式应用至关重要。

    JAX-WS API, JAX-RS API

    JAX-RS的实现有多个,如Jersey、RESTEasy、RESTlet等,它们为开发人员提供了方便的工具集,使得构建RESTful服务变得更加简单和高效。 综上所述,JAX-WS和JAX-RS都是Java平台中处理Web服务的重要工具,但它们的侧...

    JAX-RS Extension

    4. **RESTlet框架**:RESTlet是一个开源的JAX-RS实现,它不仅提供了标准的REST服务开发支持,还引入了组件模型,允许更细粒度的服务构建。RESTlet支持多种角色,如客户端、服务器端和网关,使得开发者可以更轻松地...

    restlet_jax-rs列子(客户端+服务端)

    总的来说,"restlet_jax-rs例子"提供了一个实用的教程,展示了如何结合使用RESTlet和JAX-RS创建和消费REST服务。通过这个例子,开发者可以学习如何构建可扩展、模块化的RESTful应用程序,同时享受到Java生态系统的...

    Restlet开发实例

    首先,我们来看看"RESTLET开发实例(一)基于JAX-RS的REST服务.doc"。JAX-RS是Java API for RESTful Web Services的简称,它是Java平台上的标准,用于创建RESTful服务。在这个实例中,你将学习如何使用Restlet框架结合...

    RESTlet-jee-2.0.9自用.rar

    "RESTLET开发实例(一)基于JAX-RS的REST服务"可能是包含的一个教程或指南,它向读者展示了如何使用RESTlet和JAX-RS来构建REST服务。这个实例可能涵盖以下内容: 1. **基本概念**:解释RESTful原则和JAX-RS的核心...

    RESTLET开发

    - `org.restlet.ext.jaxrs.jar`:RESTLET的JAX-RS扩展 - `org.restlet.ext.json.jar`:RESTLET JSON扩展 - `org.restlet.ext.servlet.jar`:RESTLET Servlet扩展 3. **定义实体类** 创建一个名为`Student`的...

    integration-camel-restlet:在CXF JAX-RS上将集成服务作为Jar集成到外部Rest服务

    一体化骆驼座如何通过HTTP与两个服务进行互通的示例: 其中之一是集成服务,该服务使用Camel和... 第二个是外部独立的Rest服务,该服务基于CXF JAX-RS,打包为WAR存档+交付以在带有端口9094的Jetty服务器上启动。

    Restlet学习的三篇文章

    下面,我们将深入探讨基于JAX-RS和Restlet的REST服务开发,以及如何将Restlet与Spring框架整合。 1. **JAX-RS与REST服务开发** JAX-RS(Java API for RESTful Web Services)是Java平台上的标准API,用于简化REST...

    restlet-jee-2.0.3

    7. **JAX-RS兼容性**:Restlet 2.x版本开始支持JAX-RS(Java API for RESTful Web Services),这使得Restlet与Java标准的REST接口保持一致,方便开发者迁移和集成。 8. **Internationalization and Security**:...

    RESTlet自用2

    总的来说,RESTlet自用2可能是一个基于RESTlet 2.0版本并结合Spring框架的个人项目,该项目可能涉及到了RESTful服务的开发、JAX-RS标准的实现以及Spring的集成。相关的学习资料,如"MHT"文件和"PPT",提供了理论知识...

    restlet所需jar包一

    标题"restlet所需jar包一"表明我们正在讨论的是Restlet框架的依赖库文件,这些.jar文件是运行或开发基于Restlet的应用程序所必需的。在Java开发中,.jar文件是Java Archive的缩写,它们包含了编译后的类文件和其他...

    Jersy经典(教你如何用Jersy构建REST)

    构建RESTful Web服务的第一步是从一个简单的“Hello World”应用程序入手,这不仅可以帮助我们熟悉开发环境的搭建,还能掌握Jersey和JAX-RS的基础知识。为了开发基于Jersey的Web项目,你需要准备以下工具和库: - ...

    NCC-OpenAPI示例文档.zip

    UAP在Restlet框架之上,选择了官方JAX-RS扩展,并且在扩展的基础上与NC进行了集成。 主要jar包 modules/uapws/pubuapfw_restframeworkLevel-1.jar UAP平台的扩展主要集中在uap.ws.*中,同时还少量修改了官方的jax-rs...

    REST开发指南

    **Jersey 项目** 和 JAX-RS(Java API for RESTful Web Services)是 Java 社区中最受欢迎的 RESTful Web 服务开发框架之一。 - **JAX-RS 规范**:定义了如何使用 Java 类和注解来实现 RESTful 服务。它允许开发者...

    JAVA.WEB服务.构建与运行

     《Java Web 服务:构建与运行(影印版)》提供了对Java的API的一个全面介绍,包括针对XML Web服务的JAX-WS和针对RESTful Web服务的JAX-RS。《Java Web服务:构建与运行》通过提供混合架构概述、完整的工作代码示例...

    RESTful Java Web Services (2009).pdf

    - **JBoss's JAX-RS RESTEasy**:基于JAX-RS标准的RESTful框架,提供了一系列扩展来简化RESTful服务的开发。 - **Struts 2 with the REST plugin**:Struts 2是一个流行的MVC框架,通过集成REST插件支持RESTful...

    Restlet与Spring 集成

    它遵循JAX-RS(Java API for RESTful Web Services)规范,提供了丰富的API来处理HTTP请求和响应,简化了REST服务的开发。 Spring框架则是一个全面的企业应用开发框架,提供了依赖注入(Dependency Injection, DI)...

    org.restlet-1.1.7.jar.zip

    7. **模块化**:Restlet框架被划分为多个模块,如核心模块、JAX-RS模块等,可以根据项目需求选择引入必要的模块。 8. **与其他技术的集成**:Restlet可以轻松集成到Spring、Guice等其他Java框架中,也支持JAXB和...

Global site tag (gtag.js) - Google Analytics