原文: https://howtodoinjava.com/jersey/jaxrs-jersey-exceptionmapper/

在 Jersey ExceptionMapper示例中,我们将学习在开发 Jersey RESTful Web 服务时使用ExceptionMapper接口处理自定义异常。 出于演示目的,我正在修改为Jersey 下载文件示例编写的源代码。

  1. Table Of Contents
  2. 1\. Jersey custom exception with ExceptionMapper
  3. 2\. How to throw exception from REST API
  4. 3\. Demo

1. Jersey ExceptionMapper – 创建自定义异常

要在基于 JAX-RS 的 Web 服务中处理自定义异常,您应该创建一个异常类,然后实现ExceptionMapper接口。

  1. package com.howtodoinjava.jersey;
  2. import javax.ws.rs.core.Response;
  3. import javax.ws.rs.ext.ExceptionMapper;
  4. import javax.ws.rs.ext.Provider;
  5. @Provider
  6. public class MissingFileException extends Exception implements
  7. ExceptionMapper<MissingFileException>
  8. {
  9. private static final long serialVersionUID = 1L;
  10. public MissingFileException() {
  11. super("No File found with given name !!");
  12. }
  13. public MissingFileException(String string) {
  14. super(string);
  15. }
  16. @Override
  17. public Response toResponse(MissingFileException exception)
  18. {
  19. return Response.status(404).entity(exception.getMessage())
  20. .type("text/plain").build();
  21. }
  22. }

2. 如何从 REST API 引发异常

现在,如果在所需位置找不到用户请求的文件,则可以抛出MissingFileException

  1. package com.howtodoinjava.jersey;
  2. import java.io.File;
  3. import java.io.IOException;
  4. import java.nio.file.Files;
  5. import java.nio.file.Paths;
  6. import javax.ws.rs.GET;
  7. import javax.ws.rs.Path;
  8. import javax.ws.rs.PathParam;
  9. import javax.ws.rs.core.MediaType;
  10. import javax.ws.rs.core.Response;
  11. import javax.ws.rs.core.StreamingOutput;
  12. @Path("/download")
  13. public class JerseyService
  14. {
  15. @GET
  16. @Path("/{fileName}")
  17. public Response downloadPdfFile(final @PathParam("fileName") String fileName) throws MissingFileException
  18. {
  19. final String fullFilePath = "C:/temp/" + fileName;
  20. File file = new File(fullFilePath);
  21. if(file.exists() == false){
  22. throw new MissingFileException(fileName + " does not existing on this server !!");
  23. }
  24. StreamingOutput fileStream = new StreamingOutput()
  25. {
  26. @Override
  27. public void write(java.io.OutputStream output) throws IOException
  28. {
  29. try
  30. {
  31. java.nio.file.Path path = Paths.get(fullFilePath);
  32. byte[] data = Files.readAllBytes(path);
  33. output.write(data);
  34. output.flush();
  35. }
  36. catch (IOException e)
  37. {
  38. throw new IOException("Error while reading file :: '"+fileName+"' !!");
  39. }
  40. }
  41. };
  42. return Response
  43. .ok(fileStream, MediaType.APPLICATION_OCTET_STREAM)
  44. .header("content-disposition","attachment; filename = '"+fileName)
  45. .build();
  46. }
  47. }

3. Jersey 异常处理示例

现在该测试 Jersey 异常映射器了。 现在,让我们看看找不到文件时会发生什么。

3.1 当用户要求正确的文件时

Jersey 异常处理 – Jersey `ExceptionMapper`示例 - 图1

找到文件时没有异常

3.2 当用户要求提供未知文件时

Jersey 异常处理 – Jersey `ExceptionMapper`示例 - 图2

找不到文件时带有自定义消息的 404

3.3 未捕获的异常处理

如果要在进入用户屏幕之前处理所有未捕获的异常,则必须映射Throwable本身。

  1. package com.howtodoinjava.jersey.provider;
  2. import javax.ws.rs.core.Response;
  3. import javax.ws.rs.ext.ExceptionMapper;
  4. import javax.ws.rs.ext.Provider;
  5. @Provider
  6. public class UncaughtException extends Throwable implements ExceptionMapper<Throwable>
  7. {
  8. private static final long serialVersionUID = 1L;
  9. @Override
  10. public Response toResponse(Throwable exception)
  11. {
  12. return Response.status(500).entity("Something bad happened. Please try again !!").type("text/plain").build();
  13. }
  14. }

请问您有关 jaxrs 异常映射器示例的问题。

学习愉快!