Hol*_*ger 6 java gwt tomcat unhandled-exception
我使用Tomcat 7和Lo4j作为我的所有服务器日志,使用GWT作为客户端(仅限AJAX调用).所有未处理的异常都记录在我的catalina.log中.
现在我想捕获所有异常并添加一些用户特定的Tomcat SessionData.
有几种方法:
实现这一目标的最佳方法是什么?
根据我对您的问题的理解,您可以尝试使用以下两种方法中的至少一种:
如果您可以访问所有servlet的源代码,那么可以使用一个基本的超级servlet进行一些重构,该servlet负责记录/使用AJAX透明地工作的任何请求,没有错误转发指令,也没有全局异常处理程序.假设您使用service(ServletRequest,ServletResponse)servlet入口点(但是您可以为每个do*()方法执行以下操作),那么您可以创建一个抽象的超级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>
Run Code Online (Sandbox Code Playgroud)
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());
}
}
}
Run Code Online (Sandbox Code Playgroud)
public final class Servlet1 extends BasicServlet {
@Override
protected void doService(ServletRequest request, ServletResponse response) {
out.println("I'm servlet #1");
}
}
Run Code Online (Sandbox Code Playgroud)
public final class Servlet2 extends BasicServlet {
@Override
protected void doService(ServletRequest request, ServletResponse response) {
out.println("I'm servlet #2");
}
}
Run Code Online (Sandbox Code Playgroud)
此方法的一个优点是除了更改servlet类而不依赖于外部配置或上下文之外,您不需要配置任何其他内容.缺点是你总是必须延伸BasicServlet.
我现在没有真正测试它,有关更多信息,请参阅http://docs.oracle.com/javaee/6/api/javax/servlet/Filter.html.过滤器允许拦截每个请求(我们在调试和将异常写入公共日志文件时使用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>
Run Code Online (Sandbox Code Playgroud)
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() {
}
}
Run Code Online (Sandbox Code Playgroud)
希望这可以帮助.
只需重写 GWT 函数 doUnexpectedFailure 即可。
@Override
protected void doUnexpectedFailure(Throwable t) {
ServerLog.error(t.getMessage(), t);
super.doUnexpectedFailure(t);
}
Run Code Online (Sandbox Code Playgroud)