NeQrhk 2015-12-08 02:27 采纳率: 50%
浏览 1552
已采纳

java web写了过滤器,作用显示一个servlet执行的时间,不过显示在哪里呢?

package exa;
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;

public class TimerFilter implements Filter{
private FilterConfig config = null;
public void init(FilterConfig config) throws ServletException{
this.config=config;
}
public void destroy(){
config = null;
}
public void doFilter(ServletRequest request,ServletResponse response,FilterChain chain)throws IOException,ServletException{
long before = System.currentTimeMillis();
chain.doFilter(request,response);
long after = System.currentTimeMillis();
String name=" ";
if(request instanceof HttpServletRequest){
name = ((HttpServletRequest)request).getRequestURI();
}
config.getServletContext().log(name+":"+(after-before)+"ms");
}
}

  • 写回答

3条回答 默认 最新

  • 毕小宝 博客专家认证 2015-12-08 06:21
    关注

    过滤器是作用于所有的Action的,在进入action之前,或者之后对请求的预处理或者对响应结果的后处理的。
    你可以对Action的响应作后处理,将你计算的执行时间放入response中,在浏览器上显示。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?