有几种方法可以自定义JAX-RS的错误处理行为。这是三种更简单的方法。
第一种方法是创建一个扩展
WebApplicationException的
Exception类。
例:
public class NotAuthorizedException extends WebApplicationException { public NotAuthorizedException(String message) { super(Response.status(Response.Status.UNAUTHORIZED) .entity(message).type(MediaType.TEXT_PLAIN).build()); }}
并抛出此新创建的异常,你只需:
@Path("accounts/{accountId}/") public Item getItem(@PathParam("accountId") String accountId) { // An unauthorized user tries to enter throw new NotAuthorizedException("You Don't Have Permission");}
注意,你不需要在throws子句中声明异常,因为WebApplicationException是运行时异常。这将向客户端返回401响应。
第二种更简单的方法是
WebApplicationException直接在代码中直接构造实例 。只要你不必实现自己的应用程序异常,这种方法就行。
例:
@Path("accounts/{accountId}/")public Item getItem(@PathParam("accountId") String accountId) { // An unauthorized user tries to enter throw new WebApplicationException(Response.Status.UNAUTHORIZED);}
此代码也向客户端返回401。
当然,这只是一个简单的例子。如果需要,可以使Exception更为复杂,并且可以生成所需的http响应代码。
另一种方法是包装现有的
Exception,可能是
ObjectNotFoundException使用小型包装器类来包装,该类实现
ExceptionMapper带有
@Provider注释的接口。这告诉
JAX-RS运行时,如果引发了包装的
Exception,则返回中定义的响应代码
ExceptionMapper。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)