最近,我开始使用Jersey API开发一个Restful Web服务项目。 在线提供了一些教程,但是我遇到了异常处理方面的一些问题,而且在使用JaxB和提供异常处理方法的完整项目中找不到任何地方。 因此,一旦我能够使用带有异常处理和客户端程序的Jersey API创建一个Restful Web服务,我决定编写本教程来帮助每个人都开始使用Jersey。

谁应该使用本教程

本教程适用于对使用Jersey API和JaxB开发和部署Restful Web Services感兴趣的Java程序员。

先决条件

本教程的范围是使用Jersey API来创建Restful Web服务以及使用Java客户端程序调用Web服务以及使用工具测试Web服务。 为了轻松理解本教程,需要对Java,Web服务,XML,Maven和任何应用程序服务器(JBoss / Tomcat)有基本的了解。

使用的软件和工具

  • JDK版本1.6.0_37
  • Apache Maven 3.0.3
  • Mac OS X 10.8.2
  • JBoss 4.2.2(您可以使用任何应用程序服务器,例如Tomcat,Glassfish等)
  • Eclipse Indigo(任何支持Maven的Java IDE)

在Eclipse和Jersey中创建Maven项目

在Eclipse中创建一个Maven项目,它将为您提供基本的项目结构。 我已经将GroupId设置为“ JD”,将artifactID设置为“ my-jersey-project”,但是您可以提供任何您喜欢的东西。 一旦完成项目的开发,图像将如下图所示。


Jersey Web服务项目说明

pom.xml :项目配置详细信息,请注意提供的jersey依赖项,其他详细信息对于任何Maven项目都是通用的。

<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>JD</groupId><artifactId>my-jersey-project</artifactId><version>0.0.1-SNAPSHOT</version><packaging>war</packaging><dependencies><dependency><groupId>com.sun.jersey</groupId><artifactId>jersey-server</artifactId><version>1.14</version></dependency><dependency><groupId>com.sun.jersey</groupId><artifactId>jersey-servlet</artifactId><version>1.14</version></dependency><dependency><groupId>com.sun.jersey</groupId><artifactId>jersey-client</artifactId><version>1.14</version></dependency></dependencies><build><finalName>${artifactId}-${version}</finalName><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><configuration><source>1.6</source><target>1.6</target></configuration></plugin><plugin><artifactId>maven-war-plugin</artifactId><version>2.1-alpha-2</version><configuration><packagingExcludes>WEB-INF/lib/servlet-api-*.jar</packagingExcludes></configuration></plugin><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-dependency-plugin</artifactId><version>2.0</version><executions><execution><id>unpack</id><phase>install</phase><goals><goal>unpack</goal></goals><configuration><artifactItems><artifactItem><groupId>${groupId}</groupId><artifactId>${artifactId}</artifactId><version>${version}</version><type>${packaging}</type><overWrite>true</overWrite><outputDirectory>${project.build.directory}/${artifactId}-${version}-exploded.${packaging}</outputDirectory></artifactItem></artifactItems></configuration></execution></executions></plugin></plugins></build>
</project>

EmpRequest.java :请求对象的Java Bean。 这里要注意的重要事情是@XmlRootElement批注,用于将类映射到XML元素。

package com.jd.model;import javax.xml.bind.annotation.XmlRootElement;@XmlRootElement(name = 'empRequest')
public class EmpRequest {private int id;private String name;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;}
}

EmpResponse.java :响应对象的Java bean。

package com.jd.model;import javax.xml.bind.annotation.XmlRootElement;@XmlRootElement(name = 'empResponse')
public class EmpResponse {private int id;private String name;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;}}

ErrorResponse.java :在发生异常的情况下将作为响应发送的Java Bean。

package com.jd.model;import javax.xml.bind.annotation.XmlRootElement;@XmlRootElement(name = 'errorResponse')
public class ErrorResponse {private String errorCode;private int errorId;public String getErrorCode() {return errorCode;}public void setErrorCode(String errorCode) {this.errorCode = errorCode;}public int getErrorId() {return errorId;}public void setErrorId(int errorId) {this.errorId = errorId;}}

EmpNotFoundException.java:Web服务中引发的普通异常类。

package com.jd.exception;public class EmpNotFoundException extends Exception {private static final long serialVersionUID = 4351720088030656859L;private int errorId;public int getErrorId() {return errorId;}public EmpNotFoundException(String msg, int errorId) {super(msg);this.errorId = errorId;}public EmpNotFoundException(String msg, Throwable cause) {super(msg, cause);}
}

jboss-web.xml :为Web服务定义JBoss servlet上下文。

<jboss-web><context-root>jd</context-root>
</jboss-web>

web.xml :Web服务的部署描述符。 因此,任何带有URI“ http:// <HOST>:<POST> / jd / rest / *”的请求都将由Jersey ServletContainer servlet处理。 要注意的重要事项是为“ com.sun.jersey.config.property.packages”传递的init-param值。 这定义了jersey将在哪个程序包中查找Web服务类。 此属性必须指向您的资源类。 它还在子包中查找资源类。

<?xml version='1.0' encoding='UTF-8'?>
<web-app id='WebApp_ID' 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/javaeehttp://java.sun.com/xml/ns/javaee/web-app_2_5.xsd'><display-name>My Jersey Project</display-name><!-- Jersey Servlet configurations --><servlet><servlet-name>Jersey REST Service</servlet-name><servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class><init-param><param-name>com.sun.jersey.config.property.packages</param-name><param-value>com.jd</param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>Jersey REST Service</servlet-name><url-pattern>/rest/*</url-pattern></servlet-mapping><!-- Jersey Servlet configurations --></web-app>

EmpRouter.java :处理不同类型请求的资源类。

  • @Path(“ / emp”)–具有URI http:// <HOST>:<PORT> / jd / rest / emp /的所有请求将由该资源类处理。
  • @Path(“ / getEmp”)–使用URI http:// <HOST>:<PORT> / jd / rest / emp / getEmp的所有请求都将通过此方法处理。
  • @POST –此注释定义所使用的HTTP方法应为POST。 其他一些可能的值是@ GET,@ PUT,@ DELETE
  • @Consumes(MediaType.APPLICATION_XML)–该方法接受XML元素
  • @Produces(MediaType.APPLICATION_XML)–该方法返回XML元素
package com.jd.router;import com.jd.exception.EmpNotFoundException;
import com.jd.model.*;import javax.ws.rs.Consumes;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import javax.xml.bind.JAXBElement;@Path('/emp')
public class EmpRouter {@POST@Path('/getEmp')@Consumes(MediaType.APPLICATION_XML)@Produces(MediaType.APPLICATION_XML)public Response getEmp(JAXBElement<EmpRequest> empRequest)throws EmpNotFoundException {EmpResponse empResponse = new EmpResponse();if (empRequest.getValue().getId() == 1) {empResponse.setId(empRequest.getValue().getId());empResponse.setName(empRequest.getValue().getName());} else {throw new EmpNotFoundException('Wrong ID', empRequest.getValue().getId());}return Response.ok(empResponse).build();}
}

EmpNotFoundExceptionMapper.java :异常Mapper类,将EmpNotFoundException映射到Response对象。 该类应具有批注@Provider。 此类应位于web.xml中为资源类提供的包中。 toResponse()方法的实现会生成ErrorResponse对象,并将其设置为Response对象中的Entity,状态为INTERNAL_SERVER_ERROR。

package com.jd.exceptionmapper;import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import javax.ws.rs.ext.ExceptionMapper;
import javax.ws.rs.ext.Provider;import com.jd.exception.EmpNotFoundException;
import com.jd.model.ErrorResponse;@Provider
public class EmpNotFoundExceptionMapper implementsExceptionMapper<EmpNotFoundException> {public EmpNotFoundExceptionMapper() {}public Response toResponse(EmpNotFoundException empNotFoundException) {ErrorResponse errorResponse = new ErrorResponse();errorResponse.setErrorId(empNotFoundException.getErrorId());errorResponse.setErrorCode(empNotFoundException.getMessage());return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(errorResponse).type(MediaType.APPLICATION_XML).build();}}

我们的Web服务已准备就绪,只需构建它即可创建WAR文件并将其部署在应用程序服务器中。

EmpClient.java :这是一个示例Java程序,通过它可以调用我们的Web服务。 我们正在使用jersey客户端API调用服务,并基于响应状态将响应实体解析为EmpResponse或ErrorResponse类。

package com.jd.client;import javax.ws.rs.core.MediaType;import com.jd.model.EmpRequest;
import com.jd.model.EmpResponse;
import com.jd.model.ErrorResponse;
import com.sun.jersey.api.client.Client;
import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.WebResource;public class EmpClient {/*** @param args*/public static void main(String[] args) {String uri = 'http://localhost:8080/jd/rest/emp/getEmp';EmpRequest request = new EmpRequest();//set id as 1 for OK responserequest.setId(2);request.setName('PK');try{Client client = Client.create();WebResource r=client.resource(uri);ClientResponse response = r.type(MediaType.APPLICATION_XML).post(ClientResponse.class,request );System.out.println(response.getStatus());if(response.getStatus() == 200){EmpResponse empResponse = response.getEntity(EmpResponse.class);System.out.println(empResponse.getId() + '::'+empResponse.getName());}else{ErrorResponse exc = response.getEntity(ErrorResponse.class);System.out.println(exc.getErrorCode());System.out.println(exc.getErrorId());}}catch(Exception e){System.out.println(e.getMessage());}}}

我希望该教程足够简单,可以使用Jersey编写并编写您的第一个Restful Web服务。
如果您遇到任何问题或需要进一步的说明,请告诉我。

参考: 休息使用Jersey – 开发人员食谱博客上的JCG合作伙伴 Pankaj Kumar 提供的JAXB,异常处理和客户端程序的完整教程 。

翻译自: https://www.javacodegeeks.com/2012/10/rest-using-jersey-complete-tutorial-with-jaxb-exception-handling-and-client-program.html

休息使用Jersey –包含JAXB,异常处理和客户端程序的完整教程相关推荐

  1. jaxb 处理_休息使用Jersey –包含JAXB,异常处理和客户端程序的完整教程

    jaxb 处理 最近,我开始使用Jersey API开发一个Restful Web服务项目. 在线提供了一些教程,但是我遇到了异常处理方面的一些问题,而且在使用JaxB并提供异常处理方法的完整项目中找 ...

  2. 西门子博图WinCC V 15大型自动化系统项目,包含多台服务器客户端项目

    西门子博图WinCC V 15大型自动化系统项目,包含多台服务器客户端项目,系统采用安全1516F -3PN/DP 外挂多台精智面板,1200PLC ET200SP 变频器 对整个工艺过程PID DC ...

  3. Spring Restful Web服务示例 - 使用JSON/Jackson和客户端程序

    Spring Restful Web服务示例 - 使用JSON/Jackson和客户端程序 Spring是最广泛使用的Java EE框架之一.我们之前已经看到了如何使用Spring MVC来创建基于J ...

  4. Spring Restful Web服务示例 - 使用JSON,Jackson和客户端程序

    Spring Restful Web服务示例 - 使用JSON,Jackson和客户端程序 Spring是最广泛使用的Java EE框架之一.我们之前已经看到了如何使用Spring MVC来创建基于J ...

  5. 在.NET客户端程序中使用多线程

    在.NET客户端程序中使用多线程通常认为在编写程序中用到多线程是一个高级的编程任务,容易发生错误.在本月的栏目中,我将在一个Windows窗体应用程序中使用多线程,它具有实际的意义,同时尽量使事情简单 ...

  6. 0729------Linux网络编程----------使用 select 、poll 和 epoll 模型 编写客户端程序

    1.select 模型 1.1 select 函数原型如下,其中 nfds 表示的描述符的最大值加1(因为这里是左闭右开区间),中间三个参数分别表示要监听的不同类型描述符的集合,timeout用来表示 ...

  7. 客户端程序自动更新(升级)的方式

    from:https://blog.csdn.net/woaitingting1985/article/details/72954652 一.C/S自动更新原理 C/S程序自动升级是一个很重要的功能, ...

  8. mysql5.5客户端_MySQL 5.5/5.6——概述 MySQL 客户端程序

    本文内容 mysql mysqladmin mysqlcheck mysqldump mysqlimport mysqlshow mysqlslap 参考资料 mysql mysql 是一个可以输入行 ...

  9. ONVIF协议网络摄像机(IPC)客户端程序开发(3):理解什么是Web Services

    ONVIF协议网络摄像机(IPC)客户端程序开发(3):理解什么是Web Services 1. 专栏导读 本专栏第一篇文章「专栏开篇」列出了专栏的完整目录,按目录顺序阅读,有助于你的理解,专栏前面文 ...

最新文章

  1. Django Abstract Models使用下划线设置related_name
  2. 【STM32】GPIO之LED
  3. linux两个命令一起,paste命令 – 合并两个文件
  4. sql in转换为join_同一个SQL语句,为啥性能差异咋就这么大呢?(1分钟系列)
  5. Java 在「权力的游戏」里,能活到第几集?
  6. 蓝桥杯 ALGO-5 算法训练 最短路
  7. require()和library()有什么区别?
  8. Python: 分数运算
  9. input标签在谷歌浏览器记住密码下的一个自动填充BUG
  10. java day25【Junit单元测试 、反射 、 注解】
  11. 昨晚我把900W+数据,从17s优化到300ms
  12. 阿里巴巴Java开发文档2020版学习-日期时间
  13. 批判性思维--如何高效学习
  14. Vue todos案例
  15. 【机器学习基础】IV和WOE值
  16. ajax实现分页操作
  17. win10 系统识别不了移动硬盘
  18. 深度学习中需要的矩阵计算
  19. 【Oracle SQL数据库-教学2】--- Oracle数据库基础
  20. EasyExcel实现Mysql数据库Excel数据导出

热门文章

  1. redis集群搭建报错-(error) CLUSTERDOWN The cluster is down
  2. 自定义类加载器(ClassLoader + URLClassLoader)
  3. java自定义外部接口_如何使用可外部化的接口在Java中自定义序列化
  4. cognito_将Amazon Cognito与单页面应用程序(Vue.js)集成
  5. packt_Packt发行的$ 5 Java编程书籍:精通Java 9,Java 9高性能
  6. cloudwatch_将CloudWatch Logs与Cloudhub Mule集成
  7. java使用泛型后消除泛型_如何以及何时使用泛型
  8. oracle idm_批准Oracle IDM中的特定Web服务
  9. maven junit测试_使用Maven Failsafe和JUnit @Category将集成测试与单元测试分开
  10. meetup_使用RxNetty访问Meetup的流API