java - 捕获所有 Tomcat (GWT) servlet 中所有未处理异常的最佳方法

标签 java gwt tomcat unhandled-exception

我将 Tomcat 7 和 Lo4j 用于所有服务器日志,将 GWT 用于客户端(仅 AJAX 调用)。 我所有未处理的异常都记录在我的 catalina.log 中。

现在我想捕获所有异常并添加一些用户特定的 Tomcat SessionData。

有几种方式:

  • try catch 所有 servlet(一定有更好的解决方案)。
  • http://tomcat.apache.org/tomcat-7.0-doc/aio.html : 我将不得不更改我的连接器,我不知道我是否可以在事件处理程序 (EventType.ERROR) 中使用 Tomcat session 。
  • 更好的方法?

实现此目标的最佳方法是什么?

最佳答案

根据我从您的问题中了解到的情况,您可以尝试至少使用以下两种方式之一:

基本日志记录 Servlet

如果您可以访问所有 servlet 的源代码,您可以使用一个基本的 super servlet 进行一些重构,该 super servlet 负责记录/任何与 AJAX 透明工作的请求,没有错误转发指令,并且没有全局异常处理程序。假设您使用 service(ServletRequest,ServletResponse) 作为 servlet 入口点(但您也可以对每个 do*() 方法执行以下操作),那么您可以创建一个抽象 super servlet 并简单地从它继承您的 servlet。

<servlet>
    <servlet-name>servlet1</servlet-name>
    <servlet-class>stackoverflow.Servlet1</servlet-class>
</servlet>

<servlet>
    <servlet-name>servlet2</servlet-name>
    <servlet-class>stackoverflow.Servlet2</servlet-class>
</servlet>

<servlet-mapping>
    <servlet-name>servlet1</servlet-name>
    <url-pattern>servlet1</url-pattern>
</servlet-mapping>

<servlet-mapping>
    <servlet-name>servlet2</servlet-name>
    <url-pattern>servlet2</url-pattern>
</servlet-mapping>
public abstract class BasicServlet extends HttpServlet {

    /**
     * Won't let it be {@code abstract} - we don't want to force any sub-servlet to implement this method.
     */
    protected void doService(ServletRequest request, ServletResponse response) {
    }

    @Override
    public final void service(ServletRequest request, ServletResponse response) {
        try {
            doService(request, response);
        } catch ( Throwable ex ) {
            err.println(ex.getMessage());
        }
    }

}
public final class Servlet1 extends BasicServlet {

    @Override
    protected void doService(ServletRequest request, ServletResponse response) {
        out.println("I'm servlet #1");
    }

}
public final class Servlet2 extends BasicServlet {

    @Override
    protected void doService(ServletRequest request, ServletResponse response) {
        out.println("I'm servlet #2");
    }

}

此方法的一个优点是,除了更改 servlet 类之外,您不需要配置任何其他内容,并且不依赖于外部配置或上下文。缺点是您始终必须扩展 BasicServlet

过滤器

我现在并没有真正测试它,更多信息请参阅 http://docs.oracle.com/javaee/6/api/javax/servlet/Filter.html .过滤器允许拦截每个请求(我们在调试并将异常写入公共(public)日志文件时为我们的 JSP 使用这样的过滤器实现)。缺点是不能保证过滤器可以涵盖每个异常/情况,例如,如果任何过滤器都在您自己的过滤器之前。

<filter>
    <filter-name>exceptionLoggingFilter</filter-name>
    <filter-class>stackoverflow.ExceptionLoggingFilter</filter-class>
</filter>

<filter-mapping>
    <filter-name>exceptionLoggingFilter</filter-name>
    <url-pattern>*</url-pattern> <!-- we will process every request -->
</filter-mapping>
public final class ExceptionLoggingFilter implements Filter {

    @Override
    public void init(FilterConfig filterConfig) {
    }

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain) {
        try {
            filterChain.doFilter(request, response);
        } catch ( Throwable ex ) {
            err.println(ex);
        }
    }

    @Override
    public void destroy() {
    }

}

希望这对您有所帮助。

关于java - 捕获所有 Tomcat (GWT) servlet 中所有未处理异常的最佳方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14054146/

相关文章:

java - 通过 SWT Browser/SWT BrowserFunction 从 GWT 应用程序调用 Java 方法

tomcat - Spring Boot 排除 Tomcat 依赖

maven - 找不到 Artifact 并且无法解析依赖关系

java - 如何嵌入 Internet 请求代码并获得在一个 OnClickListener 中实现的结果

java - 使用 GSON 反序列化嵌套对象

java - 在 Firebase 中获取查询

java - 为什么 GWT 不序列化异常的原因链?

java - 插入并发 HashMap

android - 将网络应用程序移植到Phonegap的路径问题

apache - 在同一个 Apache 上运行 htdocs 和 clusterd tomcat webapp