1.过滤器的概念
用于拦截客户端和服务器之间的消息,并且过滤二者之间的传递的数据,在项目中我们常常实现Filter接口并且重写其中的doFilter()方法来创建一个过滤器。
2.字符编码过滤器
在这之前我们经常使用的字符编码转换是在每个servlet中的post方法写入
resp.setCharacterEncoding("utf-8");
resp.setContentType("text/html;charset=utf-8");
代码,而用过滤器的话,我们不需要每次都写入这两行代码,字符编码过滤器如下所示:
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import java.io.IOException;
@WebFilter("/*")//所有的方法执行都必须使用该过滤器
public class FilterEncoding implements Filter {
public void destroy() {
}
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
resp.setCharacterEncoding("utf-8");
resp.setContentType("text/html;charset=utf-8");
chain.doFilter(req, resp);
}
public void init(FilterConfig config) throws ServletException {
}
}
在这里我们只需要实现Filter接口重写里面的doFilter()方法,就可以实现字符编码的过滤器了。
3.防止盗链接
当然我们也可以通过过滤器来实现防止盗链接
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebFilter("/user/*")//user文件夹下的文件执行此方法
public class FilterLogin implements Filter {
public void destroy() {
}
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
/*由于ServletRequest是HttpServletRequest
的父类所以在这里要实现他们的子类
*/
HttpServletRequest request=(HttpServletRequest)req;
HttpServletResponse response=(HttpServletResponse)resp;
String name = (String) request.getSession().getAttribute("name");
//拿到登录页面存储的name值,并对其进行判断
if (name!=null){
chain.doFilter(req, resp);//程序接着进行
}else {
response.sendRedirect("../index.jsp");
//程序重定向到index.jsp页面 ../的意思是返回上一级目录
}
}
public void init(FilterConfig config) throws ServletException {
}
}
这样就可以实现防止盗链接了。