1

Java フィルターの doFilter() メソッドのライフサイクルがわかりません。メソッドの開始時にリクエストで開始時間を設定するかどうか疑問に思っています.メソッドで停止時間を設定する方法または場所があり、リクエストの開始から返事が来る時間は?最終ブロックを含む doFilter() メソッドを見たことがありますが、そこで応答に停止時間を設定するのが適切かどうか疑問に思っていましたか?

4

1 に答える 1

7
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;

public class ResponseTimerFilter implements Filter {
  protected FilterConfig config;

  public void init(FilterConfig config) throws ServletException {
    this.config = config;
  }

  public void destroy() {
  }

  public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
      throws ServletException, IOException {
    long startTime = System.currentTimeMillis();
    chain.doFilter(request, response);
    long elapsed = System.currentTimeMillis() - startTime;
    String name = "servlet";
    if (request instanceof HttpServletRequest) {
      name = ((HttpServletRequest) request).getRequestURI();
    }

    config.getServletContext().log(name + " took " + elapsed + " ms");
  }
}

web.xml

<filter>
  <filter-name>Timing Filter</filter-name>
  <filter-class>com.omh.filters.ResponseTimerFilter</filter-class>
</filter>

<filter-mapping>
  <filter-name>Timing Filter</filter-name>
  <url-pattern>/*</url-pattern>
</filter-mapping>
于 2013-04-17T03:16:25.953 に答える