通过过滤器filter校验JWT令牌

该文章介绍了如何通过实现ServletFilter接口,创建一个拦截器来检查请求是否来自已登录用户。当请求URL不包含login时,拦截器会尝试从请求头中获取JWT令牌并进行解析。如果解析失败或者令牌不存在,系统将返回未登录的响应。
摘要由CSDN通过智能技术生成

通过servlet拦截器拦截非登录状态的请求

package com.lei.filter;

import com.lei.utils.JwtUtils;


import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

/*
* 在启动类加上@ServletComponentScan代表对servlet组件的支持
*           /login:       只有访问/login路径时才会被拦截
*           /login/*:     访问/login下的所有资源都会被拦截
*           /*:           访问所有资源都会被拦截
*/
@WebFilter(urlPatterns = "/*")//设置浏览器要拦截的请求
public class FilterDemo implements Filter {
    @Override//拦截请求后调用
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        HttpServletRequest req = (HttpServletRequest) request;
        HttpServletResponse resp = (HttpServletResponse) response;
        //1.获取请求url
        String url = req.getRequestURL().toString();
        //2.判断请求url是否包含login,如果包含则放行
        if (url.contains("login")){
            chain.doFilter(req,resp);//放行操作
            return;//让放行后不在执行后面的代码
        }
        //3.获取请求头中的令牌token
        String jwt = req.getHeader("token");
        //4.解析令牌
        try {
            JwtUtils.parseJwt(jwt);
        } catch (Exception e) {
//            e.printStackTrace();
            System.out.println("令牌错误");
            resp.getWriter().write("未登录11111");
            return;
        }
        //5.放行
        chain.doFilter(req,resp);//放行操作
        System.out.println("放行后执行");//放行后执行的操作
    }
    @Override//初始化方法,只调用一次
    public void init(FilterConfig filterConfig) throws ServletException {
        System.out.println("init方法被执行");
    }
    @Override//销毁行方法,只调用一次
    public void destroy() {
        System.out.println("destroy销毁方法被执行");
    }
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值