springboot添加拦截器

1,在annotation里面创建java类,这里创建的文件名为InterceptorUtil

bash 复制代码
package org.appcenter.wx.annotation;


import org.appcenter.db.service.VisitWebsiteService;
import org.appcenter.wx.service.UserTokenManager;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class InterceptorUtil implements HandlerInterceptor {
    @Autowired
    VisitWebsiteService visitWebsiteService;


    /**
     * 添加访客记录,同一个用户一天算一条记录,所有未登录的用户算一条
     */
     //在业务处理器处理请求之前被调用。预处理,可以进行编码、安全控制、权限校验等处理;
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        String appcenterToken = request.getHeader("Token");
        Integer userId;
        if (appcenterToken == null || appcenterToken.isEmpty()) {
            userId = 0;
        } else {
            userId = UserTokenManager.getUserId(appcenterToken);
            if (userId == null) {
                userId = 0;
            }

        }
        visitWebsiteService.addVisitors(userId);

        return true;
    }
    
    //在业务处理器处理请求执行完成后,生成视图之前执行
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {


    }

   //DispatcherServlet完全处理完请求后被调用,可用于清理资源等。返回处理(已经渲染了页面);
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {


    }
}

2,在config里创建类MyWebAppConfigurer 并实现WebMvcConfigurer

bash 复制代码
package org.appcenter.wx.config;

import org.appcenter.wx.annotation.InterceptorUtil;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.config.annotation.*;

//@EnableWebMvc
@Configuration
public class MyWebAppConfigurer implements WebMvcConfigurer {

    @Bean
    public HandlerInterceptor getMyInterceptor() {
        return new InterceptorUtil();
    }

    //需要拦截的路径,/**表示需要拦截所有请求
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
//        //注册一个拦截器
        registry.addInterceptor(getMyInterceptor())
                .addPathPatterns("/app/ad/**")
                .addPathPatterns("/app/homePage/**")
                .excludePathPatterns("/swagger-resources/**", "/webjars/**", "/v2/**", "/swagger-ui.html", "/swagger-ui.html/**");
    }

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("swagger-ui.html")
                .addResourceLocations("classpath:/META-INF/resources/");
        registry.addResourceHandler("/webjars/**")
                .addResourceLocations("classpath:/META-INF/resources/webjars/");
    }

}
相关推荐
掘金者阿豪9 分钟前
Kavita+cpolar 打造随身数字书房,让资源不再混乱,通勤 、出差都能随心读。
后端
心之语歌30 分钟前
Spring Security api接口 认证放行
后端
用户83562907805139 分钟前
Python 实现 PPT 转 HTML
后端·python
0xDevNull43 分钟前
MySQL索引进阶用法
后端·mysql
舒一笑44 分钟前
程序员效率神器:一文掌握 tmux(服务器开发必备工具)
运维·后端·程序员
UIUV1 小时前
Splitter学习笔记(含RAG相关流程与代码实践)
后端·langchain·llm
cipher2 小时前
HAPI + 设备指纹认证:打造更安全的远程编程体验
前端·后端·ai编程
雨中飘荡的记忆2 小时前
保证金系统入门到实战
java·后端
Nyarlathotep01132 小时前
Java内存模型
java
秋水无痕2 小时前
从零搭建个人博客系统:Spring Boot 多模块实践详解
前端·javascript·后端