获取Token来验证权限

首先需要了解过滤器和拦截器的区别以及运行顺序

图片来自@程序员内点事在这里插入图片描述

有些时候需要在过滤中写跨域请求的处理

这里Token的验证就在拦截器里 当然写在过滤器里也行


import lombok.extern.slf4j.Slf4j;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.util.Arrays;
import java.util.List;


/**
 * @Author XuZhuHong
 * @CreateTime 2021/12/1 9:12
 */
@Configuration
public class MyConfig {
    @Order
    @Component
    @Slf4j
    public class AuthFilter implements Filter {

        String errorInterface = "/LoginController/request";//兜底方法
        //白名单接口
        private static List< String > whiteList = Arrays.asList(
                "/LoginController/login",
                "/LoginController/request"
        );

        //过滤器  这个过滤器用来处理跨域请求  验证token
        @Override
        public void doFilter(ServletRequest request,
                             ServletResponse response,
                             FilterChain chain) throws IOException, ServletException {

            //接口转换
            HttpServletRequest req = (HttpServletRequest) request;

            //白名单接口放行的操作(即不需要验证Token)
            String path = req.getServletPath()
            for (String s : whiteList) {
                if (path.contains(s)) {
                    chain.doFilter(request, response);
                    return;
                }
            }

            //中间写逻辑代码,判断Token是否正确,失败则返回false
            String token = req.getHeader("Token"); //从请求头中得到token
            if (token == null || token.trim().length() == 0) {
                //没有Token直接转发到错误请求
                request.getRequestDispatcher(errorInterface).forward(request, response);
                return;
            } else {
                chain.doFilter(request, response);
                return;
            }
        }
    }
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值