spring拦截器

package com.shoufubang.web.interceptor;

import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
import org.springframework.web.servlet.HandlerInterceptor; 
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter; 
 
 
public class MyInterceptor extends HandlerInterceptorAdapter {
  
   @Override
   public boolean preHandle(HttpServletRequest request, HttpServletResponse response,
                              Object handler) throws Exception {
         // 获得请求路径的uri
         String uri = request.getRequestURI();

         // 判断路径是登录验证,是的话执行Controller中定义的方法
         if(uri.endsWith("/login")) {
             return true;
         }
         if(uri.endsWith("/companylogin")) {
             return true;
         }

         // 进入登录页面,判断session中是否值,有的话继续执行
             if(request.getSession() != null && request.getSession().getAttribute("adminUser") != null) {
               return true;
             }
             if(request.getSession() != null && request.getSession().getAttribute("adminCompany") != null) {
               return true;
             }
        

         // 其他情况判断session中是否有key,有的话继续用户的操作
         if(request.getSession() != null && request.getSession().getAttribute("adminUser") != null) {
             return true;
         }
         if(request.getSession() != null && request.getSession().getAttribute("adminCompany") != null) {
             return true;
         }

         // 以上所有情况都不成立则进入登录页面
         response.sendRedirect(request.getContextPath() + "/login.jsp");
         return false;
   }
  
 }

个人感觉这个拦截器还是比较全面的

转载于:https://www.cnblogs.com/dengheng/p/5798954.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值