1.filter的作用
- 在HttpServletRequest請求到達Servlet之前,攔截客戶的HttpServletRequest
- 根據需要檢查HttpServletRequest的相關信息,修改頭信息和數據
- 在HttpServletResponse到達客戶端之前可以進行攔截
- 在HttpServletResponse到達客戶端之前可以進行檢查,也可以修改頭信息和數據
2.實現方式
- 定義一個類,繼承自javax.servlet.Filter類
- 實現javax.servlet.Filter的init(),destroy(),doFilter()方法
- 配置filter在web.xml或者filter的代碼中
3.具體實現
package com.filter;
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import java.io.IOException;
public class LogFilter implements Filter {
private FilterConfig config;
@Override
public void init(FilterConfig filterConfig) throws ServletException {
this.config=filterConfig;
}
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
ServletContext context=config.getServletContext();
long time= System.currentTimeMillis();
System.out.println("過濾開始");
System.out.println(time);
HttpServletRequest request=(HttpServletRequest)servletRequest;
HttpSession session=request.getSession(true);
String loginpage=config.getInitParameter("loginpage");
if(session.getAttribute("username")==null&&!request.getContextPath().endsWith(loginpage)){
servletRequest.getRequestDispatcher(loginpage).forward(servletRequest,servletResponse);
}else{
System.out.println(request.getContextPath());
filterChain.doFilter(servletRequest,servletResponse);
long atime= System.currentTimeMillis();
System.out.println(time);
System.out.println("過濾結束");
System.out.println("請求被處理時間是:"+request.getContextPath()+"("+(atime-time)+")");
}
}
@Override
public void destroy() {
config=null;
}
}
4.在web.xml中的配置方法
<filter>
<filter-name>logs</filter-name>
<filter-class>com.filter.LogFilter</filter-class>
<init-param>
<param-name>loginpage</param-name>
<param-value>/login.jsp</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>logs</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
說明:filter.doFilter調用是用來區分攔截的前后的
doFilter的使用可以進行權限的驗證,日志的記錄等方法
