笔记 AsyncHandlerInterceptor 拦截器

Spring拦截器HandlerInterceptor和HandlerInterceptorAdaptericon-default.png?t=M0H8https://www.cnblogs.com/june0816/p/14355853.html

一、HandlerInterceptor

1. 接口,定义了三个方法

2. 可以自定义拦截器类,直接实现该接口进行拦截

public interface HandlerInterceptor {
    // 预处理,在业务处理之前被调用,返回true继续执行,返回false中断执行
    boolean preHandle(HttpServletRequest var1, HttpServletResponse var2, Object var3) throws Exception;

    // 在业务处理之后,视图生成之前被调用
    void postHandle(HttpServletRequest var1, HttpServletResponse var2, Object var3, ModelAndView var4) throws Exception;

    // 在视图生成之后被调用
    void afterCompletion(HttpServletRequest var1, HttpServletResponse var2, Object var3, Exception var4) throws Exception;
}

二、HandlerInterceptorAdapter是抽象类,间接实现了HandlerInterceptor接口

1. HandlerInterceptorAdapter--->AsyncHandlerInterceptor--->HandlerInterceptor

2. 可以自定义拦截器类,继承HandlerInterceptorAdapter抽象类进行拦截

3. 适配器模式,不必全部实现HandlerInterceptor的三个方法,只需要根据业务需求,实现特定的方法

三、如何使用

1. 创建一个拦截器类,继承HandlerInterceptorAdapter抽象类

2. 重写preHandle()方法,通过HttpServletRequest获取参数、URI、Cookie、Session等进行业务处理

@Slf4j
@Component
public class LoginInterceptor extends HandlerInterceptorAdapter {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        String ip = request.getParameter("ip");
        return true;
    }
}

3. 配置拦截器

a. spring mvc配置到xml里

<!--登录拦截验证-->
    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/**"/>
            <bean class="com.a.b.LoginInterceptor"/>
        </mvc:interceptor>
    </mvc:interceptors>

b. spring boot

新建一个类,实现WebMvcConfigurer接口

重写addInterceptors()方法

把刚才新建的拦截器实例,添加进拦截器列表里

@Configuration
@Slf4j
public class InterceptorConfig implements WebMvcConfigurer {
    @Autowired
    LoginInterceptor loginInterceptor;

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(loginInterceptor).addPathPatterns("/**");
    }
}

四、运行流程

1. 拦截器是一个列表,按顺序执行拦截器的preHandle()方法

2. 如果preHandle()方法返回false,不再往下执行

3. 执行主方法,即controller里的接口

4. 逆序执行postHandle()方法

5. view页面渲染

6. 逆序执行afterCompletion()方法

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
FileUploadInterceptor是一个拦截器,用于在Spring MVC中处理文件上传请求。它可以在处理请求之前拦截请求,处理文件上传,并在后续处理请求之前将上传的文件信息添加到请求中。 以下是FileUploadInterceptor的一些笔记: 1. 引入依赖 在Maven项目中,需要在pom.xml文件中添加以下依赖: ``` <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.4</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.6</version> </dependency> ``` 2. 配置拦截器Spring MVC的配置文件中,需要配置FileUploadInterceptor拦截器。以下是一个示例配置: ``` <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**"/> <bean class="com.example.interceptor.FileUploadInterceptor"/> </mvc:interceptor> </mvc:interceptors> ``` 3. 处理文件上传 在FileUploadInterceptor中,可以使用Apache Commons FileUpload库来处理文件上传。以下是一个示例方法: ``` private List<FileItem> getFileItems(HttpServletRequest request) throws Exception { ServletFileUpload fileUpload = new ServletFileUpload(); List<FileItem> fileItems = fileUpload.parseRequest(request); return fileItems; } ``` 此方法将解析请求并返回上传的文件项列表。 4. 将文件信息添加到请求中 在FileUploadInterceptor中,可以使用MultipartHttpServletRequest类来将文件信息添加到请求中。以下是一个示例方法: ``` private void addFileItemsToRequest(HttpServletRequest request, List<FileItem> fileItems) throws Exception { MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request; for (FileItem fileItem : fileItems) { if (!fileItem.isFormField()) { multipartRequest.getFileMap().put(fileItem.getFieldName(), new CommonsMultipartFile(fileItem)); } } } ``` 此方法将遍历文件项列表,并将每个文件项添加到MultipartHttpServletRequest中。注意,我们只添加非表单字段的文件项。 以上是FileUploadInterceptor的一些笔记,希望对你有帮助!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值