SpringMVC中拦截器的简单使用

步骤一:创建拦截器类

首先,我们需要创建一个拦截器类,该类需要实现HandlerInterceptor接口。这个接口定义了三个方法,分别在请求处理前、请求处理后和视图渲染后执行。

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 MyInterceptor implements HandlerInterceptor {

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        // 在请求处理前执行,返回true表示继续执行后续操作,返回false表示终止执行
        System.out.println("拦截器:请求处理前");
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        // 在请求处理后执行,但在视图渲染前执行
        System.out.println("拦截器:请求处理后");
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        // 在整个请求处理完毕后执行,包括视图渲染完毕
        System.out.println("拦截器:请求完成");
    }
}

步骤二:创建配置类

java 复制代码
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;

@Configuration
public class MyInterceptorConfig extends WebMvcConfigurerAdapter {

    @Bean
    public MyInterceptor myInterceptor() {
        return new MyInterceptor();
    }

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        // 注册拦截器并指定拦截路径
        registry.addInterceptor(myInterceptor()).addPathPatterns("/secured/**");
    }
}

上述配置类使用了@Configuration注解,表示这是一个配置类。通过@Bean注解将MyInterceptor注册为一个Bean,并在addInterceptors方法中配置拦截器的路径。

步骤三:应用示例

接下来,让我们创建一个简单的Controller,以及一个包含拦截逻辑的方法。

java 复制代码
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller
public class MyController {

    @RequestMapping("/secured/hello")
    @ResponseBody
    public String securedHello() {
        return "Hello from secured endpoint!";
    }
}

步骤四:测试

现在,当我们访问 "/secured/hello" 路径时,拦截器的逻辑将会执行。

相关推荐
洛洛呀。14 小时前
DDD架构为何拆分Entity层?从MVC到领域模型的演进之道
架构·mvc·ddd
毕设源码-赖学姐2 天前
【开题答辩全过程】以 基于.NET MVC的婚庆服务系统设计为例,包含答辩的问题和答案
mvc·.net
小旭95273 天前
Spring MVC :从入门到精通(下)
java·后端·spring·mvc
希望永不加班4 天前
如何在 SpringBoot 里自定义 Spring MVC 配置
java·spring boot·后端·spring·mvc
稻草猫.4 天前
MyBatis进阶:动态SQL与MyBatis Generator插件使用
java·数据库·后端·spring·mvc·mybatis
鬼蛟4 天前
Spring MVC
java·spring·mvc
鬼蛟4 天前
Spring_MVC
java·spring·mvc
StackNoOverflow5 天前
Spring MVC零散知识点记录
java·spring·mvc
码界奇点5 天前
基于Spring MVC和MyBatis的妖气山视频管理系统设计与实现
java·spring·毕业设计·mvc·mybatis·源代码管理
波波0075 天前
ASP.NET MVC 中的返回类型全集详解
后端·asp.net·mvc