How can I get the stack trace when 500 server error happens in Jersey?

半城伤御伤魂 提交于 2019-11-28 12:07:01

问题


When in jersey server I have server 500 error:

  • In server response don´t have stack trace or some info.

  • In Eclipse console don´t have exception stack trace

I try to catch exception in server and print trace in console, but nothing happens

How can I get the stack trace when 500 server error happens?


回答1:


Most of the time, a generic ExceptionMapper will do the trick.

@Provider
public class DebugMapper implements ExceptionMapper<Throwable> {
    @Override
    public Response toResponse(Throwable t) {
        t.printStackTrace()
        return Response.serverError()
            .entity(t.getMessage())
            .build();
    }
}

Then just register it

ResourceConfig config = new ResourceConfig()
        .register(DebugMapper.class);

Sometime the exception will get swallowed by Jersey when the exception is not mapped, and you will not see what happened. This usually works, when the problem is at the Jersey level.

See also:

  • WebApplicationException and Mapping Exceptions to Responses


来源:https://stackoverflow.com/questions/45757856/how-can-i-get-the-stack-trace-when-500-server-error-happens-in-jersey

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!