java 拦截器

1、新建一个filter ,名称为LoginFilter实现Filter类

修改doFilter()方法为:

public void doFilter(ServletRequest req, ServletResponse res,
          FilterChain chain) throws IOException, ServletException {
HttpServletRequest request = (HttpServletRequest) req;
        request.setCharacterEncoding("utf-8");
HttpServletResponse response = (HttpServletResponse) res;
response.setCharacterEncoding("utf-8");

//得到request和response,将request和response的编码设为utf-8
HttpSession session = request.getSession();//得到session
User user = (User) session.getAttribute("user");//从session中得到user 如果用户已登录则user不为空,否则为空
String url = request.getRequestURI();//得到地址栏
        if (user == null && url.indexOf("doLogin.do") < 0//判断用户是否已登录
           && url.indexOf("login.do") < 0
           && !url.endsWith("index.jsp") // 对URL地址为此结尾的文件不过滤
           && !url.endsWith(".js")
           && url.indexOf(".css") < 0
           && url.indexOf(".png") < 0
           && url.indexOf(".gif") < 0
           && url.indexOf("/servlet/") < 0) {
response.sendRedirect(request.getContextPath() + "/index.jsp");
}else {
chain.doFilter(request, response);
}
    }

在web.xml中加入拦截器的配置:

 <!-- 过滤器配置 -->
  <filter>
  <filter-name>LoginFilter</filter-name>
  <filter-class>com.test.oa.web.filter.LoginFilter</filter-class>//拦截器方法所在的位置
  </filter>
  
  <filter-mapping>
  <filter-name>LoginFilter</filter-name>
  <url-pattern>/*</url-pattern>
  </filter-mapping>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值