- 浏览: 1222884 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (883)
- Spring (101)
- Swing (1)
- Mysql (21)
- Js (59)
- Jsp (2)
- Hibernate (19)
- Myeclipse (5)
- SqlServer 2000 (2)
- poi (15)
- Java (70)
- SSH (12)
- Html (47)
- Fusion Charts (1)
- C\C++ (2)
- 汇编 (36)
- Jquery (37)
- Struts2 (6)
- Ubuntu (16)
- powerDesinger (4)
- Jboss (3)
- JAX-RS (13)
- JAXB (5)
- JAX-WS (11)
- JMS (4)
- WebSocket (8)
- PHP (16)
- Flash (1)
- maven (3)
- Oracle (8)
- HttpClient (6)
- sqlserver (19)
- svn (5)
- Tomcat (3)
- Jdbc (3)
- EsayUi (11)
- 微信公众平台 (19)
- IIS (2)
- Freemarker (11)
- Comet (1)
- Spring MVC (85)
- JBoss Seam (3)
- 二维码 (9)
- Spring Security (4)
- Ehcache (3)
- Apache Shiro (7)
- jackson (16)
- JPA (8)
- jcaptcha (2)
- RSA (2)
- Ajax (6)
- 跟我学Shiro (0)
- Spring4 (19)
- 跟我学spring3 (0)
- css (32)
- excel (4)
- Filter (3)
- 微信公众帐号开发教程 (0)
- Android (6)
- log4j (6)
- 淘宝接口 (17)
- 支付集成 (3)
- 单点登录 (3)
- Html5 (27)
- 移动平台前端 (3)
- Linux (44)
- FusionCharts (27)
- Json Jackson Xml (5)
- 方培工作室-微信开发 (0)
- Apache与Tomcat与IIS整合 (10)
- Nginx (17)
- webService (2)
- apache (4)
- lucene (3)
- lodop (2)
- Shiro (3)
- zTree (2)
- ireport (12)
- Servlet3.0 (5)
- 前端美工 (19)
- AngularJS (1)
- C#开发微信门户及应用 (0)
- Shell (3)
- bat脚本 (16)
- Bootstrap (26)
- Less (10)
- photoshop (6)
- Redis (6)
- Mongodb (10)
- MyBatis (3)
- 数据结构 (0)
- 读写分离-主从复制 (0)
- JFinal (0)
- 百度地图api (3)
- hadoop-hbase-hive-spark (3)
- WebStorm (2)
- Quartz (5)
- ios (0)
- Mina (8)
- Android Studio (4)
- Ratchet教程 (0)
- 移动端重构系列 (1)
- cubic-bezier贝塞尔曲线CSS3动画工具 (1)
- nginx+tomcat+memcached集群 (0)
- 集群 (0)
- ZooKeeper (3)
- Dubbo (0)
- vpn (0)
- kafka (0)
- JVM垃圾回收机制 (0)
- 微信小程序 (0)
- Lua (0)
- Hystrix (0)
- Vue.js (0)
- mycat (0)
- Openresty (0)
- springBoot (0)
- 新分类 (0)
- guava (0)
- 大数据 (0)
- Sentinel (0)
最新评论
-
JackMacing:
中文怎么解决?
SpringMVC与iReport(JasperReports) 5.6整合开发实例 -
18335864773:
用pageoffice把.可以实现在线的文档操作.直接转pdf ...
转:使用jasperreport动态生成pdf,excel,html -
linhao0907:
推荐一款轻量开源的支付宝组件:https://github.c ...
关于Alipay支付宝接口(Java版) -
songronghu:
太好了,非常有用,谢谢分享~
Java ConcurrentModificationException 异常分析与解决方案 -
wzwahl36:
http://www.atool.org/json2javab ...
Java下利用Jackson进行JSON解析和序列化
首先先看一下HTTP中定义的响应码及其意义:
响应码
|
含义
|
100
|
继续
|
101
|
分组交换协议
|
200
|
OK
|
201
|
被创建
|
202
|
被采纳
|
203
|
非授权信息
|
204
|
无内容
|
205
|
重置内容
|
206
|
部分内容
|
300
|
多选项
|
301
|
永久地传递
|
302
|
找到
|
303
|
参见其他
|
304
|
未改动
|
305
|
使用代理
|
307
|
暂时重定向
|
400
|
错误请求
|
401
|
未授权
|
402
|
要求付费
|
403
|
禁止
|
404
|
未找到
|
405
|
不允许的方法
|
406
|
不被采纳
|
407
|
要求代理授权
|
408
|
请求超时
|
409
|
冲突
|
410
|
过期的
|
411
|
要求的长度
|
412
|
前提不成立
|
413
|
请求实例太大
|
414
|
请求URL太大
|
415
|
不支持的媒体类型
|
416
|
无法满足的请求范围
|
417
|
失败的预期
|
500
|
内部错误
|
501
|
未被使用
|
502
|
网关错误
|
503
|
不可用的服务
|
504
|
网关超时
|
505
|
HTTP版本未被支持
|
一、成功
从 200 到 399 为成功码,表示请求处理成功。
如果方法返回值不为null,则返回码是 200;如果返回值为 null 或者为 void,则返回码为 204,表示无内容。
二、错误
从 400 到 599 表示处理错误。
例如 404表示网页未找着;如果请求的期望的返回交换类型不对,则返回 406,表示不可接爱;如果请求的方法未找着,则返回 405,表示方法不允许,这个返回结果对于HEAD和OPTIONS请求方法例外,对于HEAD会试图去查找能处理相同URI的GET方法;对于OPTION,会返回一些自动生成的信息。
三、复杂的响应
对于不能简单处理的返回信息,则可以返回javax.ws.rs.core.Response对象:
- public abstract class Response {
- public abstract Object getEntity();
- public abstract int getStatus();
- public abstract MultivaluedMap<String, Object> getMetadata();
- ...
- }
Response对象不能直接创建,需要通过javax.ws.rs.core.Response.ResponseBuilder来创建:
- public abstract class Response {
- ...
- public static ResponseBuilder status(Status status) {...}
- public static ResponseBuilder status(int status) {...}
- public static ResponseBuilder ok() {...}
- public static ResponseBuilder ok(Object entity) {...}
- public static ResponseBuilder ok(Object entity, MediaType type) {...}
- public static ResponseBuilder ok(Object entity, String type) {...}
- public static ResponseBuilder ok(Object entity, Variant var) {...}
- public static ResponseBuilder serverError() {...}
- public static ResponseBuilder created(URI location) {...}
- public static ResponseBuilder noContent() {...}
- public static ResponseBuilder notModified() {...}
- public static ResponseBuilder notModified(EntityTag tag) {...}
- public static ResponseBuilder notModified(String tag) {...}
- public static ResponseBuilder seeOther(URI location) {...}
- public static ResponseBuilder temporaryRedirect(URI location) {...}
- public static ResponseBuilder notAcceptable(List<Variant> variants) {...}
- public static ResponseBuilder fromResponse(Response response) {...}
- ...
- }
ResponseBuilder是一个用来创建单个Response实例的工厂类, 首先将要创建的response对象的状态存起来,最后当状态设置完成了,就使用builder去初始化Response:
- public static abstract class ResponseBuilder {
- public abstract Response build();
- public abstract ResponseBuilder clone();
- public abstract ResponseBuilder status(int status);
- public ResponseBuilder status(Status status) {...}
- public abstract ResponseBuilder entity(Object entity);
- public abstract ResponseBuilder type(MediaType type);
- public abstract ResponseBuilder type(String type);
- public abstract ResponseBuilder variant(Variant variant);
- public abstract ResponseBuilder variants(List<Variant> variants);
- public abstract ResponseBuilder language(String language);
- public abstract ResponseBuilder language(Locale language);
- public abstract ResponseBuilder location(URI location);
- public abstract ResponseBuilder contentLocation(URI location);
- public abstract ResponseBuilder tag(EntityTag tag);
- public abstract ResponseBuilder tag(String tag);
- public abstract ResponseBuilder lastModified(Date lastModified);
- public abstract ResponseBuilder cacheControl(CacheControl cacheControl);
- public abstract ResponseBuilder expires(Date expires);
- public abstract ResponseBuilder header(String name, Object value);
- public abstract ResponseBuilder cookie(NewCookie... cookies);
- }
例如:
- @Path("/textbook")
- public class TextBookService {
- @GET
- @Path("/restfuljava")
- @Produces("text/plain")
- public Response getBook() {
- String book = ...;
- ResponseBuilder builder = Response.ok(book);
- builder.language("fr").header("Some-Header", "some value");
- return builder.build();
- }
- }
四、Cookie
JAX-RS使用了一个简单的类去表示一个cookie值,它就是javax.ws.rs.core.NewCookie:
- public class NewCookie extends Cookie {
- public static final int DEFAULT_MAX_AGE = −1;
- public NewCookie(String name, String value) {}
- public NewCookie(String name, String value, String path,
- String domain, String comment,
- int maxAge, boolean secure) {}
- public NewCookie(String name, String value, String path,
- String domain, int version, String comment,
- int maxAge, boolean secure) {}
- public NewCookie(Cookie cookie) {}
- public NewCookie(Cookie cookie, String comment,
- int maxAge, boolean secure) {}
- public static NewCookie valueOf(String value)
- throws IllegalArgumentException {}
- public String getComment() {}
- public int getMaxAge() {}
- public boolean isSecure() {}
- public Cookie toCookie() {}
- }
要返回Cookie,只需要传入它到Response中:
- @GET
- public Response get() {
- NewCookie cookie = new NewCookie("key", "value);
- ResponseBuilder builder = Response.ok("hello", "text/plain");
- return builder.cookies(cookie).build();
- }
五、状态类别
除了直接写数据外,JAX-RS定义了一个状态值的枚举类别:
- public enum Status {
- OK(200, "OK"),
- CREATED(201, "Created"),
- ACCEPTED(202, "Accepted"),
- NO_CONTENT(204, "No Content"),
- MOVED_PERMANENTLY(301, "Moved Permanently"),
- SEE_OTHER(303, "See Other"),
- NOT_MODIFIED(304, "Not Modified"),
- TEMPORARY_REDIRECT(307, "Temporary Redirect"),
- BAD_REQUEST(400, "Bad Request"),
- UNAUTHORIZED(401, "Unauthorized"),
- FORBIDDEN(403, "Forbidden"),
- NOT_FOUND(404, "Not Found"),
- NOT_ACCEPTABLE(406, "Not Acceptable"),
- CONFLICT(409, "Conflict"),
- GONE(410, "Gone"),
- PRECONDITION_FAILED(412, "Precondition Failed"),
- UNSUPPORTED_MEDIA_TYPE(415, "Unsupported Media Type"),
- INTERNAL_SERVER_ERROR(500, "Internal Server Error"),
- SERVICE_UNAVAILABLE(503, "Service Unavailable");
- public enum Family {
- INFORMATIONAL, SUCCESSFUL, REDIRECTION,
- CLIENT_ERROR, SERVER_ERROR, OTHER
- }
- public Family getFamily()
- public int getStatusCode()
- public static Status fromStatusCode(final int statusCode)
- }
每个Status的值都关联的到一个特定HTTP的返回值族,这个族由Status.Family标识。例如 100范围的值被认识是信息性的;200范围的是成功;300范围的也是成功,但是被重定向的;400是client错误;500是服务器错误。
Response.status()和ResponseBuilder.status()都接受一个Status值,例如:
六、javax.ws.rs.core.GenericEntity
当处理Response的返回对象(entity)时,如果是一个类似于MessageBodyWriter这样的支持泛型的对象,则问题来了: isWriteable()方法需要有泛弄的信息。然后不幸的是java的泛型信息只存在编译时,不存在运行时,因此没有一个简单的方法可以得到在运行时得到泛型的信息,因此MessageBodyWriter不知道如何输出对象。
为了解决这个问题,JAX-RS提供了一个帮助类 javax.ws.rs.core.GenericEntity 。例如:
- @GET
- @Produces("application/xml")
- public Response getCustomerList() {
- List<Customer> list = new ArrayList<Customer>();
- list.add(new Customer(...));
- GenericEntity entity = new GenericEntity<List<Customer>>(list){};
- return Response.ok(entity);
- }
GenericEntity也是一个泛型模板,只需要将输出entity的泛型信息加到它上,并且把对象做为一个参数传入即可。
七、javax.ws.rs.WebApplicationException
WebApplicationException是一个内置、非检测异常,支持传入Response对象或者状态码:
- public class WebApplicationException extends RuntimeException {
- public WebApplicationException() {...}
- public WebApplicationException(Response response) {...}
- public WebApplicationException(int status) {...}
- public WebApplicationException(Response.Status status) {...}
- public WebApplicationException(Throwable cause) {...}
- public WebApplicationException(Throwable cause,
- Response response) {...}
- public WebApplicationException(Throwable cause, int status) {...}
- public WebApplicationException(Throwable cause,
- Response.Status status) {...}
- public Response getResponse() {...]
- }
当JAX-RS碰到一个WebApplicationException抛出时,它就捕获这个异常,调用它的getResponse()方法去获取Response,发回给client端。 如果应用以一个状态码或者Response初始化了WebApplicationException,则这个状态码或者Response将被用来创建真正的HTTP响应;或者,会直接返回 500, “Internal Server Error“给客户端,例如:
- @Path("/customers")
- public class CustomerResource {
- @GET
- @Path("{id}")
- @Produces("application/xml")
- public Customer getCustomer(@PathParam("id") int id) {
- Customer cust = findCustomer(id);
- if (cust == null) {
- throw new WebApplicationException(Response.Status.NOT_FOUND);
- }
- return cust;
- }
- }
这里如果没找着客户,会返回404错误
八、错误匹配
应用中可能有各种各样的,来自应用或者第三方包的异常,如果仅依赖于容器提供的错误处理方式,则可能灵活度不够: 捕获这些异常,然后包装到WebApplicationException中会让人觉得相当乏味。
这里的另外一种选择就是使用javax.ws.rs.ext.ExceptionMapper,这个对象知道怎么匹配一个抛出的异常到一个Repsonse对象上:
例如对于JPA有EntityNotFoundException:
- @Provider
- public class EntityNotFoundMapper
- implements ExceptionMapper<EntityNotFoundException> {
- public Response toResponse(EntityNotFoundException e) {
- return Response.status(Response.Status.NOT_FOUND).build();
- }
- }
注: ExceptionMapper的实现,必须加上@Provider注释
ExceptionMapper也支持异常层级关系,例如A 继承 B,如果找不到A的mapper,则会向上查找B的mapper。
最后ExceptionMapper使用JAX-RS的deployment API进行注册,可以用Application.
发表评论
-
JAX-RS入门 十二: 可伸缩的JAX-RS应用
2012-09-11 19:10 689一、HTTP Caching HTTP1.0中定义了E ... -
JAX-RS入门 十一:HATEOAS
2012-09-11 19:09 729HATEOAS全称:超媒体即状态应用引擎 (Hypermedi ... -
JAX-RS入门 十: 兼容与演进
2012-09-11 19:09 847网络服务会随着时间 ... -
JAX-RS入门 九: 内容约定(2)
2012-09-10 23:33 627JAX-RS与Conneg JAX-RS有一些用来帮助 ... -
JAX-RS入门 九: 内容约定(1)
2012-09-10 23:32 652通常一个SOA的应用都需要足够的灵活,以便于各种不同的客户端或 ... -
JAX-RS入门 七: 数据处理(2)
2012-09-10 23:31 864上节介绍了JAX-RS中怎么与一些基础的对象进行交互,这节介绍 ... -
JAX-RS入门 六: 数据处理(1)
2012-09-10 23:30 906接下来要花两小节来介绍一下JAX-RS中的数据处理(Data ... -
JAX-RS入门 五: 自动类型转换
2012-09-09 12:41 702一、默认类型转换规则 在上一节中,已经了解了怎么使用那 ... -
JAX-RS入门 四: 注入
2012-09-09 12:39 1111一、Annotations @javax.ws.rs.Pa ... -
JAX-RS入门 三 :细节
2012-09-09 12:33 749一、若希望一个Java类能够处理REST请求,则这个类必须 ... -
JAX-RS入门 二 :运行
2012-09-09 12:31 961上一节,已经成功的定义了一个REST服务,并且提供了具体的 ... -
JAX-RS入门 一 :基础
2012-09-09 12:29 1745简介 JAX-RS是一套用java实现REST服务的规范,提 ...
相关推荐
本资源“JAX-RS入门jar包集合”包含了开始学习和使用JAX-RS所需的基本库文件,这些jar包将帮助开发者快速搭建REST服务环境。下面我们将详细讲解JAX-RS的核心概念和关键组件,以及如何利用这些jar包进行实际开发。 1...
5. JAX-RS进阶:深入研究响应式编程、客户端API、资源分页和过滤,以及与其他JAX-RS规范如JAX-RPC和JSON-P的集成。 6. 开发工具与环境:设置和使用IDE(如Eclipse或IntelliJ IDEA)、Maven或Gradle构建工具,以及...
【快速入门JAX-RS】 JAX-RS是Java API for RESTful Web Services的缩写,它是Java平台上的一个标准,用于构建RESTful Web服务。REST(Representational State Transfer)是一种网络应用程序的设计风格和开发方式,...
2. **JAX-WS与JAX-RS**:JAX-WS用于构建基于SOAP的Web服务,而JAX-RS则用于构建RESTful服务。CXF支持这两种Java API,使得开发者可以根据项目需求选择适合的服务模型。 3. **客户端开发**:在“手持客户端开发资料...
4. JAX-RS教程:JAX-RS利用HTTP方法(如GET、POST、PUT和DELETE)和资源URI来处理请求。学习如何使用@Path、@GET、@POST等注解创建REST服务,并理解JSON和XML之间的转换。 5. 客户端调用:无论是SOAP还是REST服务,...
1. **Servlet和JAX-RS**:Java中的API通常通过HTTP服务器进行通信,这可能需要使用Servlet或JAX-RS(Java API for RESTful Web Services)来创建RESTful API。Servlet处理HTTP请求,而JAX-RS则简化了创建REST服务的...
- Jersey是JAX-RS(Java API for RESTful Web Services)的参考实现,用于创建RESTful服务。 - 注解驱动:使用@Path、@GET、@POST等注解来标记资源类和方法。 - 使用Response和Entity:返回HTTP响应,包括状态码...
Java中,JAX-RS(Java API for RESTful Web Services)是用于构建RESTful服务的标准API。 - 定义资源类:创建Java类表示资源,并使用`@Path`注解指定资源路径。 - 方法注解:在类的方法上使用`@GET`, `@POST`, `@...
而与RESTful服务(JAX-RS)相比,JAX-WS更适合于复杂的、基于消息交换模式的服务。 通过这个"jaxws的小demo",开发者可以快速入门JAX-WS,了解其基本用法和流程,为进一步深入学习和实践Web服务开发打下基础。在...
2. JAX-RS:Java API for RESTful Web Services,提供了一种简化的方式来创建RESTful Web服务。 3. .NET中的Web服务:Microsoft提供了ASMX和WCF(Windows Communication Foundation)框架,用于构建和消费Web服务。 ...
JAX-RS 项目的 WebSphere Liberty 项目。 /travel-businessrules包含将折扣应用于合作酒店预订的规则和规则流。 /travel-businessrules-app包含由业务规则构建的关联应用程序。 该应用程序部署在云中以在 BlueMix 上...
Java EE 7增强了JAX-RS 2.0,包括支持超媒体链接和更强大的异常处理。 通过"JavaEE-7-Samples"项目,开发者可以学习到如何在实际环境中应用这些技术,从而提升他们的Java EE开发技能。每个示例都会包含详细的代码和...
CXF是一个开源项目,它提供了多种方式来创建和消费Web服务,包括Java API for Web Services (JAX-WS) 和Java API for RESTful Web Services (JAX-RS)。这个例子代码旨在帮助用户深入理解CXF的工作原理以及在实际项目...
这个新手入门实例将帮助你理解如何使用Java和JAX-RS构建RESTful服务。通过实践,你可以更深入地学习如何处理请求参数、返回响应、使用实体类、异常处理、JSON序列化和反序列化等内容。同时,还可以探索更高级的主题...
在NetBeans 5.0中,你可以创建基于WSDL(Web服务描述语言)的SOAP服务,或者利用JAX-RS(Java API for RESTful Web Services)来构建RESTful服务。 2. **NetBeans IDE 5.0界面**: NetBeans IDE 5.0提供了一个直观...
开源bbs java java Srb4j = 用于 Java 的简单 RESTFul ...堆栈:JAX-RS + Spring + MyBatis + MySQL 开箱即用的后台门户 先决条件 JDK 8+ Maven 3.1+ MySQL 服务器 5.7+ 开发环境中的快速入门 生成 Java
【标题】:WebService入门教程 - Java WebService 【描述】:本教程旨在引导初学者了解如何使用Eclipse集成开发环境来发布基于Java语言的WebServices服务。WebServices是一种允许不同系统之间进行交互和数据交换的...
- **RESTful服务**:使用JAX-RS创建API并测试响应。 - **微服务**:可能包含如何将大型应用拆分为独立的服务。 `jboss-eap-quickstarts_8.0.x.zip`文件很可能是JBoss EAP 8.0的快速启动项目集合,这些项目提供了预...
- 使用CXF,可以通过Java API for RESTful Web Services (JAX-RS)轻松地创建RESTful服务。开发者可以使用`@Path`、`@GET`、`@POST`等注解来定义资源和操作。 - 对于SOAP服务,CXF支持JAX-WS,允许通过Java注解或者...