springboot接口开发框架——拦截器注册

定义拦截器

首先定义一个拦截器,重写请求处理前和处理后会被执行的方法

public class UserHeaderIntercepter implements HandlerInterceptor {

  @Override
  public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
    UserHeader userHeader = UserHeader.builder()
            .userId(request.getHeader("userId"))
            .version(request.getHeader("version"))
            .build();
    UserHeaderHodler.threadLocal.set(userHeader);
    return HandlerInterceptor.super.preHandle(request, response, handler);
  }

  @Override
  public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
    UserHeaderHodler.threadLocal.remove();
    HandlerInterceptor.super.afterCompletion(request, response, handler, ex);
  }
}

注册拦截器

@Configuration
public class WebConfig implements WebMvcConfigurer {

  @Bean
  public UserHeaderIntercepter userHeaderIntercepter() {
    return new UserHeaderIntercepter();
  }

  @Override
  public void addInterceptors(InterceptorRegistry registry) {
    registry.addInterceptor(userHeaderIntercepter());
    WebMvcConfigurer.super.addInterceptors(registry);
  }
}

被@Configuration注解修饰的类为配置类,在springboot项目启动的时候会被自动加载
但是只有配置类存在于当前moduel才会被加载

因为我们的拦截器定义为一个公共的moduel,其他moduel想要使用必须通过其他方式才能加载成功

加载配置类

想要加载成功,需要在resource文件下创建如下文件:
在这里插入图片描述
这样在其他moduel启动的时候就会自动加载这个文件

EnableAutoConfiguration翻译过来就是自动配置的意思

这其实是springboot实现自动化配置的核心技术

观察springboot各种starter也是根据这种方式实现了

springboot之所以不需要开发者像springmvc一样配置很多额外的信息,就是因为springboot在各种@Configuration修饰的类中完成了这些配置

github demo 地址

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot是一个开源的Java框架,用于快速构建基于Spring的应用程序。它提供了许多开箱即用的功能和插件,其中包括登录拦截。 登录拦截是一种用于验证用户身份并控制访问权限的机制。在Spring Boot中,可以使用拦截来实现登录功能。下面是一个简单的示例,演示如何使用Spring Boot创建一个轻量级的登录拦截: 1. 创建一个实现HandlerInterceptor接口拦截类,例如LoginInterceptor。 ```java import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class LoginInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 在请求处理之前进行拦截处理 // 验证用户是否已登录,如果未登录则重定向到登录页面 if (!isUserLoggedIn(request)) { response.sendRedirect("/login"); return false; } return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { // 请求处理之后但是视图渲染之前进行拦截处理 } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { // 整个请求处理完毕后进行拦截处理 } private boolean isUserLoggedIn(HttpServletRequest request) { // 判断用户是否已登录的逻辑 // 返回true表示已登录,返回false表示未登录 } } ``` 2. 在Spring Boot应用程序的配置类中注册拦截。 ```java import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; @Configuration public class WebConfig implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) { // 注册拦截,并指定拦截的路径 registry.addInterceptor(new LoginInterceptor()).addPathPatterns("/**"); } } ``` 在上述示例中,LoginInterceptor类实现了HandlerInterceptor接口,并重写了preHandle、postHandle和afterCompletion方法。preHandle方法在请求处理之前进行拦截处理,可以在此方法中验证用户是否已登录并进行相应的操作。 WebConfig类是Spring Boot应用程序的配置类,通过实现WebMvcConfigurer接口并重写addInterceptors方法,将拦截注册到应用程序中。 这样,当用户访问任何路径时,都会经过LoginInterceptor拦截的preHandle方法进行处理。如果用户未登录,则会重定向到登录页面。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值