2016-07-27 5 views
2

У меня есть сервер причалов, который начал этот путь с помощью кода примера ниже, где я написал свой собственный класс errorHandler. Через несколько исследований я получил некоторую информацию here. Но мне кажется, что этого недостаточно, чтобы получить то, что я хочу. Имя класса, который я задал для вызова сервером, - это HandleClient.Как сделать ошибку ошибки ErrorHandler в json формате в java

Так что, если ошибка 404 возникает, она отображает {"message":"HTTP error 404"}. программа работает нормально в любом случае. Но ответ находится в текстовом/обычном формате.

Моя проблема: Как настроить класс для форматирования и отображения ошибки в MIME MediaType: application/json.

У меня были бессонные ночи на этом. Будем очень благодарны всем за помощь.

public class MVCPatternNsano{ 

    public MVCPatternNsano(){ 
    } 

    public static void main(String args[]) throws JSONException, IOException{ 
     MVCPatternNsano mvcPatternNsano = new MVCPatternNsano(); 


     ServletContextHandler context = new ServletContextHandler(ServletContextHandler.SESSIONS); 
     context.setContextPath("/"); 

     Server jettyServer = new Server(9000); 
     jettyServer.setHandler(context); 
     context.setErrorHandler(new ErrorHandler()); 
     // default error handler for resources out of "context" scope 
     jettyServer.addBean(new ErrorHandler()); 

     ServletHolder jerseyServlet = context.addServlet(org.glassfish.jersey.servlet.ServletContainer.class, "/*"); 
     jerseyServlet.setInitOrder(0); 

     // Tells the Jersey Servlet which REST service/class to load. 
     jerseyServlet.setInitParameter("jersey.config.server.provider.classnames", 
       HandleClient.class.getCanonicalName()); 

     try { 
      jettyServer.start();    
      jettyServer.join(); 

     } catch (Exception ex) { 
      Logger.getLogger(HandleClient.class.getName()).log(Level.SEVERE, null, ex); 
     } finally { 
      jettyServer.destroy(); 
     } 
    } 
    /** 
    * Dummy error handler that disables any error pages or jetty related messages and returns our 
    * ERROR status JSON with plain HTTP status instead. All original error messages (from our code) are preserved 
    * as they are not handled by this code. 
    */ 
    static class ErrorHandler extends ErrorPageErrorHandler { 
     @Override 
     public void handle(String target, org.eclipse.jetty.server.Request baseRequest, HttpServletRequest request, HttpServletResponse response) throws IOException { 
      response.getWriter() 
      .append("{\"message\":\"HTTP error ") 
      .append(String.valueOf(response.getStatus())) 
      .append("\"}"); 
     } 
    } 

} 

ответ

1

Вы должны проверить Accept заголовок в HttpServletRequest.getHeader("Accept") сначала увидеть, если клиент может принимать этот тип.

Затем используйте HttpServletResponse.setContentType("text/json") для установки типа содержимого для ответа.

Или, если вы используете Jetty 9.3.11.v20160721 (или новее), вы можете переопределить метод ErrorHandler.generateAcceptableResponse(Request baseRequest, HttpServletRequest request, HttpServletResponse response, int code, String message, String mimeType) и обработать его соответствующим образом.

См.: https://github.com/eclipse/jetty.project/blob/jetty-9.3.11.v20160721/jetty-server/src/main/java/org/eclipse/jetty/server/handler/ErrorHandler.java#L196-L226 например, по его использованию.