开发Web服务的RESTful方法不断受到越来越多的关注,并且似乎正在将SOAP淘汰。 我不会讨论哪种方法更好,但是我相信我们都同意REST更轻量级。 在本教程中,我将向您展示如何使用RESTeasy开发RESTful服务以及如何将它们部署在Tomcat服务器上。 在此过程中还将创建一个基于Eclipse的Maven项目。

我最近想测试计划用于正在构建的应用程序中的REST客户端,因此我需要一种快速的方法来建立RESTful基础结构。 贾斯汀撰写了一篇很酷的指南,讲述了如何使用Spring提供RESTful服务 。 但是,我想要更快的东西,并且不要一次与Spring混为一谈。 因此,我决定使用JBoss RESTeasy 。 从官方网站:

RESTEasy是一个JBoss项目,它提供各种框架来帮助您构建RESTful Web服务和RESTful Java应用程序。 它是JAX-RS规范的完全认证且可移植的实现。 JAX-RS是新的JCP规范,它通过HTTP协议为RESTful Web服务提供Java API。
RESTEasy可以在任何Servlet容器中运行,但是还可以与JBoss Application Server进行更紧密的集成,以使用户在该环境中获得更好的体验。

可以在这里找到最新的RESTeasy版本,并在这里找到相关文档。 目前,最新版本是2.1.0.GA。 您可能还需要RESTeasy JavaDoc和JAX-RS JavaDoc 。

由于使用JBoss AS会取消整个“轻量级”概念,因此我决定与我们的老朋友Tomcat一起使用。 我从这里下载了最受欢迎的servlet容器的最新版本(7.0.5 beta)。 请注意,目前这还处于beta阶段,但是Tomcat已被证明非常强大,我认为应该不会出现任何问题。

让我们开始创建一个名为“ RESTeasyProject”的基于Eclipse的Maven项目。 所使用的原型为“ webapp-jee5”,如下图所示:

对于参数,我们将“ com.javacodegeeks”用作组ID,将“ resteasy”用作工件ID。

下一步是在我们的pom.xml文件中添加RESTeasy依赖项。 存储库URL为http://repository.jboss.org/maven2/,但是不幸的是,该存储库中提供的最新版本为2.0-beta-2。 无论如何,我们需要添加到Maven文件中的行是:

…
<repositories><repository><id>org.jboss.resteasy</id><url>http://repository.jboss.org/maven2/</url></repository>
</repositories>
…
<dependencies>
…
<dependency><groupId>org.jboss.resteasy</groupId><artifactId>resteasy-jaxrs</artifactId><version>2.0-beta-2</version>
</dependency>
<dependency><groupId>org.jboss.resteasy</groupId><artifactId>resteasy-jaxb-provider</artifactId><version>2.0-beta-2</version>
</dependency>
<dependency><groupId>org.jboss.resteasy</groupId><artifactId>resteasy-jettison-provider</artifactId><version>2.0-beta-2</version>
</dependency>
…
</dependencies>
…

resteasy-jaxrs构件引用了JAX-RS实现的核心RESTeasy类。 另外,我们同时使用resteasy-jaxb-provider和resteasy-jettison-provider,因为我们希望同时支持XML和JSON响应格式。 JAXB体系结构用于XML序列化,而Jettison框架用于编写JSON。

这是完整的pom.xml:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.javacodegeeks</groupId><artifactId>resteasy</artifactId><packaging>war</packaging><version>0.0.1-SNAPSHOT</version><name>resteasy JEE5 Webapp</name><url>http://maven.apache.org</url><repositories><repository><id>org.jboss.resteasy</id><url>http://repository.jboss.org/maven2/</url></repository></repositories><dependencies><dependency><groupId>javax.servlet</groupId><artifactId>servlet-api</artifactId><version>2.5</version><scope>provided</scope></dependency><dependency><groupId>javax.servlet.jsp</groupId><artifactId>jsp-api</artifactId><version>2.1</version><scope>provided</scope></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>3.8.1</version><scope>test</scope></dependency><dependency><groupId>org.jboss.resteasy</groupId><artifactId>resteasy-jaxrs</artifactId><version>2.0-beta-2</version></dependency><dependency><groupId>org.jboss.resteasy</groupId><artifactId>resteasy-jaxb-provider</artifactId><version>2.0-beta-2</version></dependency><dependency><groupId>org.jboss.resteasy</groupId><artifactId>resteasy-jettison-provider</artifactId><version>2.0-beta-2</version></dependency></dependencies><build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><version>2.0.2</version><configuration><source>1.5</source><target>1.5</target></configuration></plugin></plugins><finalName>resteasy</finalName></build>
</project>

首先让我们看看将在我们的服务中使用的模型类:

package com.javacodegeeks.resteasy.model;import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;@XmlRootElement(name = "employee")
public class Employee {private String employeeId;private String employeeName;private String job;@XmlElementpublic String getEmployeeId() {return employeeId;}public void setEmployeeId(String employeeId) {this.employeeId = employeeId;}@XmlElementpublic String getEmployeeName() {return employeeName;}public void setEmployeeName(String employeeName) {this.employeeName = employeeName;}@XmlElementpublic String getJob() {return job;}public void setJob(String job) {this.job = job;}}

典型的模型类,其中包含一些字段以及相应的获取器/设置器。 使用JAXB批注以指示要序列化的字段以及将它们映射到的元素。 更具体地说,使用XmlRootElement批注来指示顶级类元素。 类似地,使用XmlElement注释获取器,以将相应的JavaBean属性映射到XML元素。 默认情况下,使用属性名称,但是我们可以通过提供自定义名称来覆盖它。

现在让我们创建第一个启用RESTeasy的类,名为“ SampleService”。

package com.javacodegeeks.resteasy;import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;import com.javacodegeeks.resteasy.model.Employee;@Path("/sampleservice")
public class SampleService {private static Map<String, Employee> employees = new HashMap<String, Employee>();static {Employee employee1 = new Employee();employee1.setEmployeeId("1");employee1.setEmployeeName("Fabrizio");employee1.setJob("Software Engineer");employees.put(employee1.getEmployeeId(), employee1);Employee employee2 = new Employee();employee2.setEmployeeId("2");employee2.setEmployeeName("Justin");employee2.setJob("Business Analyst");employees.put(employee2.getEmployeeId(), employee2);}@GET@Path("/hello")@Produces("text/plain")public String hello(){return "Hello World";    }@GET@Path("/echo/{message}")@Produces("text/plain")public String echo(@PathParam("message")String message){return message;    }@GET@Path("/employees")@Produces("application/xml")public List<Employee> listEmployees(){return new ArrayList<Employee>(employees.values());}@GET@Path("/employee/{employeeid}")@Produces("application/xml")public Employee getEmployee(@PathParam("employeeid")String employeeId){return employees.get(employeeId);        }@GET@Path("/json/employees/")@Produces("application/json")public List<Employee> listEmployeesJSON(){return new ArrayList<Employee>(employees.values());}@GET@Path("/json/employee/{employeeid}")@Produces("application/json")public Employee getEmployeeJSON(@PathParam("employeeid")String employeeId){return employees.get(employeeId);        }}

如您所见,我们的服务有很多注释。 我们可以声明性地定义每个方法都会响应的HTTP方法,例如GET或POST 。 对于提供资源的URL,我们在服务和方法级别都使用PATH 。 如果方法接受参数或属于特定路径段, 则以PathParam表示。 最后, Consumes批注定义资源方法可以接受的媒体类型,而Produces定义可以生成的类型。

让我们研究更多细节。 我们将一些模拟数据存储在静态映射上,在实际的应用程序中,这些数据将被DAO取代。 请注意,模型类将由库针对XML和JSON表示形式进行序列化。 现在让我们看一下暴露的方法:

  • hello :一种仅打印具有文本/纯内容类型的预定义字符串的方法。
  • echo :此方法返回提供的任何参数。 请注意,方括号内的字段名称必须与参数名称匹配。 与上面类似的内容类型。
  • listEmployees :此方法提供模型对象列表的XML表示。 格式由Produces注释指示。
  • getEmployee :与上一个相同,但仅基于ID参数返回一个模型对象。
  • listEmployeesJSON :与XML相似,但产生的格式为JSON。
  • getEmployeeJSON :与上一个相同,但仅基于ID参数返回一个模型对象。

接下来,我们必须相应地设置Web应用程序的web.xml文件,以便RESTeasy处理传入的REST请求。 在我们的Maven项目中,可以在“ src / main / webapp / WEB-INF”目录下找到该文件。 声明文件如下所示:

<?xml version="1.0" encoding="UTF-8"?><web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"><display-name>resteasy</display-name><listener><listener-class>org.jboss.resteasy.plugins.server.servlet.ResteasyBootstrap</listener-class></listener><servlet><servlet-name>Resteasy</servlet-name><servlet-class>org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher</servlet-class></servlet><servlet-mapping><servlet-name>Resteasy</servlet-name><url-pattern>/restful-services/*</url-pattern></servlet-mapping><context-param><param-name>resteasy.scan</param-name><param-value>true</param-value>    </context-param><context-param><param-name>resteasy.servlet.mapping.prefix</param-name><param-value>/restful-services</param-value></context-param></web-app>

为了使用resteasy创建注册表,必须部署ResteasyBootstrap上下文侦听器,同时使用HttpServletDispatcher Servlet,以便将传入请求正确路由到适当的服务。 我们已经配置了名为“ Resteasy”的特定servlet,以拦截“ / restful-services / *”路径下的请求。 我们需要使用resteasy.servlet.mapping.prefix配置选项将其定义为RESTeasy框架。 请注意,该值不包含尾部斜杠或通配符。 最后,我们使用resteasy.scan开关自动扫描WEB-INF / lib jar和WEB-INF / classes目录中的各种带注释的类。 您还可以使用许多其他RESTeasy配置开关来微调应用程序的行为。

最后一步是构建项目并将其部署到servler容器。 运行Eclipse配置,然后选择“ Maven安装”。 假设一切正常,这将在项目的“目标”文件夹下生成一个名为“ resteasy.war”的网络存档。 也可以在同一目录中找到展开的文件夹。 将WAR文件复制到Tomcat的应用程序存储库,即“ apache-tomcat-7.0.5 \ webapps”文件夹。 如果尚未启动服务器,请在控制台上看到以下行:

添加扫描的资源:com.javacodegeeks.resteasy.SampleService

现在已经部署了应用程序,让我们对其进行测试。 请注意,由于所有方法都处理GET请求,因此可以使用您喜欢的浏览器并仅编写URL来执行测试。 对于懒惰的开发人员,它们在这里(在XML和JSON的情况下,我还添加了具有预期结果的公共链接):

http:// localhost:8080 / resteasy / restful-services / sampleservice / hello

http:// localhost:8080 / resteasy / restful-services / sampleservice / echo / message

http:// localhost:8080 / resteasy / restful-services / sampleservice / employees ( 链接 )
http:// localhost:8080 / resteasy / restful-services / sampleservice / employee / 1 ( 链接 )
http:// localhost:8080 / resteasy / restful-services / sampleservice / json / employees ( 链接 )
http:// localhost:8080 / resteasy / restful-services / sampleservice / json / employee / 1 ( 链接 )

请注意,完整路径包括Web应用程序上下文(“ resteasy”),我们定义的RESTeasy处理上下文(“ restful-services”),服务路径(“ sampleservice”)以及相应的方法路径。

仅此而已。 与往常一样,您可以在此处找到Eclipse项目。

相关文章 :
  • Spring3 RESTful Web服务
  • 带有Spring和Maven教程的JAX–WS
  • GWT 2 Spring 3 JPA 2 Hibernate 3.5教程– Eclipse和Maven 2展示
  • GWT Spring和Hibernate进入数据网格世界
  • 使用Spring使用Java发送电子邮件– GMail SMTP服务器示例

翻译自: https://www.javacodegeeks.com/2011/01/restful-web-services-with-resteasy-jax.html

Tomcat 7上具有RESTeasy JAX-RS的RESTful Web服务-Eclipse和Maven项目相关推荐

  1. resteasy_Tomcat 7上具有RESTeasy JAX-RS的RESTful Web服务– Eclipse和Maven项目

    resteasy 开发Web服务的RESTful方法不断受到越来越多的关注,并且似乎正在将SOAP淘汰. 我不会讨论哪种方法更好,但是我相信我们都同意REST更轻量级. 在本教程中,我将向您展示如何使 ...

  2. 使用 Jersey 和 Apache Tomcat 构建 RESTful Web 服务

    http://www.ibm.com/developerworks/cn/web/wa-aj-tomcat/ 使用 Jersey 和 Apache Tomcat 构建 RESTful Web 服务 Y ...

  3. jersey tomcat MySQL_基于jersey和Apache Tomcat构建Restful Web服务(一)

    基于jersey和Apache Tomcat构建Restful Web服务(一) 现如今,RESTful架构已然成为了最流行的一种互联网软件架构,它结构清晰.符合标准.易于理解.扩展方便,所以得到越来 ...

  4. 【报错笔记】Eclipse导入Maven项目时pom.xml报错,项目上有红感叹号。

    Eclipse导入Maven项目时pom.xml报错,项目上有红感叹号. 错误原因: pom.xml中依赖的jar包在本地仓库中不存在,但是在maven/conf/settings.xml中定义了阿里 ...

  5. eclipse运行maven项目,tomcat启动报错

    2019独角兽企业重金招聘Python工程师标准>>> 使用eclipse创建maven项目后,在pom.xml文件中添加依赖.若依赖包没有下载,eclipse会自行下载到maven ...

  6. Jboss RestEasy构建简单的RESTful Web Services示例(1)

    2019独角兽企业重金招聘Python工程师标准>>> 项目上要用到webservice,鉴于现在restful webservice比较流行,打算用restful来建立webser ...

  7. 使用RESTEasy 和 Jersey创建JAX-RS CRUD Rest Web服务

    在本教程中,我们将学习如何使用 RESTEasy 和 Jersey 创建 JAX-RS Get.POST.PUT 和 DELETE Rest Web 服务. 我们将建造什么? 我们正在构建一个简单的  ...

  8. Web服务(Apache、Nginx、Tomcat、Jetty)与应用(LAMP、CMS-WordPressGhost、Jenkins、Gitlab)

    Web服务和应用是目前信息技术领域的热门技术.如何使用Docker来运行常见的Web服务器(包括Apache.Nginx.Tomcat等),以及一些常用应用(LAMP.CMS等).包括具体的镜像构建方 ...

  9. ubuntu下idea maven项目与tomcat集成

    2019独角兽企业重金招聘Python工程师标准>>> tomcat安装 1.首先安装tomcat,当然idea内置了tomcat ,这里以idea14.10为准,tomcat内置6 ...

最新文章

  1. PCL分割:Conditional Euclidean Clustering官方历程,在自己配置环境上调错
  2. Java项目:网上花店商城系统(java+jsp+servlert+mysql+ajax)
  3. 计算机网络各种传输介质说明
  4. svn在commit后报错:is scheduled for addition, but is missing
  5. 执行计划--为查询指定查询计划
  6. QT实现maroon游戏
  7. java访问器_ONGN和java字段访问器(get,set)
  8. python计算在月球的体重_NumPy-快速处理数据--矩阵运算
  9. 部署Zipkin分布式性能追踪日志系统的操作记录
  10. 视频编解码(一):编解码器cedarc/libcedarx编译工具链配置
  11. 【SQLServer】将Job运行结果发送电子邮件通知用户
  12. Push failed: Failed with error: Authentication failed for
  13. 计算点到SVM超平面的距离
  14. Python机器学习预测算法
  15. python源代码制作星空_用python画星空源代码是什么
  16. c语言程序设计专题实验bmp,第九章 报表设计---Visual Foxpro 数据库程序设计教案1-9章全...
  17. ios 表情符号 键盘_字体键盘表情符号
  18. 【大数据开发】scala——tuple、list(含高阶方法)、wordcount案例、set、并行处理数据和sorted、sortBy、sortWith的区别
  19. windos下快捷键给文件、文件名重命名
  20. MapReduce的容错机制

热门文章

  1. leetcode初级算法5.加一
  2. HDU1231(最大连续子序列)
  3. i18n国际化登录页面
  4. JDK 9中不推荐使用Java的Observer和Observable
  5. nodejs异步测试_异步过程的自动化测试
  6. java多线程做一件事_关于Java的十件事
  7. 多维柔性作业调用_摆脱困境:从预定作业中调用安全方法
  8. Jsoup V的幕后秘密:优化的技巧和窍门
  9. jdk8 cms g1gc_G1 vs CMS vs平行GC
  10. java 解析gson_使用Java和Google GSON解析ESPN API