Filter:即过滤器,比如在用户进行网页的请求时,有些网页需要用户登录后才能访问,那你就必须设置一个过滤器来判断用户是否已近登录。新建一个Filter过滤器命名为LoginFilter,里面会有三个函数,最主要的就是doFilter里面执行的拦截方法
先新建一个Filter目录,在Filter目录下新建一个过滤器类。之后就可以再Filter里面写上自己的过滤方法了,在每次进行页面跳转或者进入页面时,都会根据你在doFilter里面所写入的过滤方法进行判断。
package com.dly.web.filter;
import com.dly.pojo.Member;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
/**
*
*/
@WebFilter(filterName = "LoginFilter",urlPatterns = {"*.action","*.jsp"})//拦截的页面
public class LoginFilter implements Filter {
/**
* 在服务器启动时就创建,调用构造器init,
* */
public void destroy() {
}
/**
* 拦截方法
* */
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
/*
*放行前
* 判断是否有session
* 有放行
* 没有,拦截,即不让调用chain.doFilter(req, resp);这条语句
*/
//1、强转,因为在你的controller/xxServlet里的get 和 post为HttpServletRequest类型
HttpServletRequest request = (HttpServletRequest) req;
//涉及到页面跳转
HttpServletResponse response = (HttpServletResponse) resp;
//准备放行的url
String urls = "/,/login.jsp,/index.action,/login.action";
//获取当前请求的url;
String requestURL = request.getRequestURI().toString();
String url = requestURL.substring(requestURL.lastIndexOf("/"));
if(urls.indexOf(url)==-1){//如果当前url不在要放行的urls中;就判断是登录
//2、获取session
HttpSession session = request.getSession();
//3、判断session是否有值
Member member = (Member)session.getAttribute("member");//之前将session保存在member中的,类型为Member类
if(member == null){
//没有session,即未登录,重定向到主页面
response.sendRedirect("pages/login.jsp");
return;//便不会执行后面的语句
}
}
chain.doFilter(req, resp);
}
public void init(FilterConfig config) throws ServletException {
System.out.print("已拦截");//这只是用来测试看是否拦截
}
}