アクセス時間をテストするFilter
1586 ワード
今日はあるリソースにアクセスするのにどれだけの時間がかかるかをテストするフィルタを書きました.
ここではデータベースに時間をかけて記録することもできます
package com.own.filter;
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;
import javax.servlet.http.HttpServletResponse;
public class CalculateTimeFilter implements Filter {
public void doFilter(ServletRequest request,ServletResponse response,FilterChain chain)throws ServletException,IOException{
//
long beginTime = System.currentTimeMillis();
//
HttpServletRequest httpRequest = (HttpServletRequest) request;
HttpServletResponse httpResponse = (HttpServletResponse) response;
chain.doFilter(httpRequest, httpResponse);
long endTime = System.currentTimeMillis();
long costTime = endTime - beginTime;
System.out.println(" "+httpRequest.getRequestURI()+" "+costTime+" ");
//httpResponse.sendRedirect("bb.jsp");
}
public void destroy() {
// TODO Auto-generated method stub
}
public void init(FilterConfig filterConfig) throws ServletException {
// TODO Auto-generated method stub
System.out.println("filter is initialized");
}
}
ここではデータベースに時間をかけて記録することもできます