springboot2.0 + token登录状态拦截器

springboot2.0我们可以继承接口HandlerInterceptor编写拦截器,实现对登录状态失效的用户进行操作拦截。



import com.shengxi.rs.common.util.StringUtils;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

/**
 * @author matthew
 * @Date: 2019年6月27日 17:41:24
 * @Description: 登陆验证拦截
 */
@Component
public class LoginStatusFilter implements HandlerInterceptor {


    private Logger logger = LoggerFactory.getLogger(LoginStatusFilter.class);

    /**
     * 请求进去controller进行请求拦截
     * 验证是否登录
     *
     * @param request  req
     * @param response resp
     * @param handler  handler
     * @return boolean
     * @throws Exception exception
     * @Description: 请求登陆验证是否处于登录状态
     * @since 1.0
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {
        String token = TokenFilter.getToken(request);
        if (StringUtils.isNull(token)) {
            response.setStatus(203);
            //未登录自动跳转界面
            logger.info("用户没有登录,重定向登陆页面");
            response.sendRedirect("/");
            return false;
        }
        //在请求处理之前进行调用(Controller方法调用之前)
        // 只有返回true才会继续向下执行,返回false取消当前请求
        return true;
    }

    /**
     * 请求进入controller后调用
     *
     * @param request      request
     * @param response     response
     * @param handler      handler
     * @param modelAndView modelAndView
     * @throws Exception Exception
     */
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {

    }

    /**
     * 请求得到响应的时候调用
     *
     * @param request  request
     * @param response response
     * @param handler  handler
     * @param ex       Exception
     * @throws Exception Exception
     */
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {

    }

 然后使用WebAppConfigurer进行拦截器注册,1.0的时候使用的是WebMvcConfigurer,但是2.0已经被告知属于过期的。所以使用替代他的WebMvcConfigurationSupport。


import com.shengxi.rs.common.filter.LoginStatusFilter;
import java.util.ArrayList;
import java.util.List;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport;

/**
 * @author matthew
 */
@Configuration
public class WebAppConfigurer extends WebMvcConfigurationSupport {
    private List<String> excludePathPatternList;

    /**
     * 这个方法用来注册拦截器,我们自己写好的拦截器需要通过这里添加注册才能生效
     *
     * @param registry 注册管理
     */
    @Override
    protected void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new LoginStatusFilter()).addPathPatterns("/**").excludePathPatterns(getUrls());
        super.addInterceptors(registry);
    }


    /**
     * 这个方法是用来配置静态资源的,比如html,js,css,等等
     *
     * @param registry 注册管理
     */
    @Override
    protected void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/static/**").addResourceLocations("classpath:/static/");
        super.addResourceHandlers(registry);
    }

    /**
     * 定义需要避免过滤的url
     *
     * @return list
     */
    private List<String> getUrls() {
        List<String> list = new ArrayList<>();
        list.add("/");
        list.add("/login");
        list.add("/index");
        list.add("/static/**");
        list.add("/static/user/css/*.css");
        list.add("/static/user/js/*.js");
        list.add("/static/user/images/*");
        this.setExcludePathPatternList(list);
        return excludePathPatternList;
    }

    public void setExcludePathPatternList(List<String> excludePathPatternList) {
        this.excludePathPatternList = excludePathPatternList;
    }
}

 

注意:一定要写对应的不拦截路径,否则会出现重定向次数过多的情况。因为程序会一直在login页面不断跳转。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

matthew_leung

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值