一、过滤器
定义:javaweb三大组件之一,对web服务器管理的所有的监听器(TestFilter,)所声明的web资源:例如,Jsp,Servlet,静态图片与文件或静态html文件等进行拦截,从而实现特殊的功能。过滤器只针对它所过滤的页面而言
二、过滤器链
java语句:chain.doFilter(request,response);
在FilterChain中,调用了Filter的doFilter()方法,web服务器会检查FilterChain对象中是否还有filter,如果有,则调用第二个filter,如果没有,则调用目标资源
体会:
CheckLoginFilter 没有过滤login.jsp,在此处可以显示登陆页面。过滤update.jsp和index.jsp,在此处不可以显示登陆页面,当FilterChain对象中没有过滤器时,则可访问update.jsp和index.jsp
代码示例:
package stu.qg.web.filter.test;
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;
public class TestFilter implements Filter{
public void destroy() {
}
public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2)
throws IOException, ServletException {
arg2.doFilter(arg0, arg1);
/*没有这条语句时,访问Login.jsp,无法获取资源;有这条语句时,仅仅只是这里过滤掉了该页面资源,导致无法直接显示该页面,还需
往后继续执行一两个过滤器才能够显示页面资源。
*/
}
public void init(FilterConfig arg0) throws ServletException {
}
}
检查且修改request字符过滤器设计:
package stu.qg.web.filter.common;
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;
public class CheckEncodingFilter implements Filter{
private String encoding="GBK";
public void destroy() {
}
public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2)
throws IOException, ServletException {
arg0.setCharacterEncoding(encoding);
arg2.doFilter(arg0, arg1);
}
public void init(FilterConfig arg0) throws ServletException {
String s=arg0.getInitParameter("encoding");
if(s != null && "".equals(s)){
encoding=s;
}
}
}
在这需要从web.xml文件中获取页面的字符格式:
<filter>
<filter-name>CheckCharacterFilter</filter-name>
<filter-class>stu.qg.web.filter.common.CheckCharacterFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CheckCharacterFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
登陆页面的过滤器设计:
package stu.qg.web.filter.sys;
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.annotation.WebFilter;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
@WebFilter(value={"/update.jsp","/index.jsp"})
public class CheckLoginFilter implements Filter{
private static Log log=LogFactory.getLog(CheckLoginFilter.class);
public void destroy() {
}
public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2)
throws IOException, ServletException {
log.info("经过了登录过滤器"); //在这个时刻,浏览器会显示登陆的jsp页面
}
public void init(FilterConfig arg0) throws ServletException {
}
}
具体怎么用,还不是太清楚。