SpringMVC源码深度解析之拦截器&过滤器&视图层&异步源码分析

本文深入探讨SpringMVC框架的核心组件与配置,包括视图层整合、拦截器使用及多线程异步处理策略。讲解了如何通过注解方式启动SpringMVC,自定义拦截器实现请求验证,并介绍了多线程提升响应速度的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SpringMVC核心

SpringMVC注解方式开启视图层

整合Jsp 视图层

@Bean
public InternalResourceViewResolver internalResourceViewResolver() {
    // 1.需要前缀
    InternalResourceViewResolver internalResourceViewResolver = new InternalResourceViewResolver();
    // 2.需要后缀
    internalResourceViewResolver.setPrefix("/WEB-INF/view/");
    internalResourceViewResolver.setSuffix(".jsp");
    return internalResourceViewResolver;
}
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
完全基于Spring注解方式启动SpringMVC

SpringMVC拦截器使用

拦截器与过滤器区别

拦截器和过滤器都是基于AOP实现的,能够对请求方法之前和之后实现拦截

过滤器是基于Servlet实现的,对web请求之前和之后实现拦截

拦截器不需要依赖servlet,不仅可以实现web请求,还可以对其它方法拦截

SpringMVC拦截器的使用

1.自定义拦截器拦截请求Token

public class TokenInterceptor implements HandlerInterceptor {
    /**
     * 请求方法前置拦截,如果返回true 表示会执行到目标方法(请求方法) 如果返回false的情况下 则不会执行目标方法。
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        String token = request.getParameter("token");
        System.out.println(">>>>token<<<<:" + token);
        if (StringUtils.isEmpty(token)) {
            response.setStatus(500);
            response.getWriter().print(" token is null");
            return false;
        }
        // 执行我们的请求方法
        return true;
    }
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("<<<postHandle>>>>");
        // 请求之后执行。
    }
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println(">>>afterCompletion<<<");
        // 请求之后执行。
    }
}

f7aac9b8e66d39229815cf914cc46916ab9.jpg

@Configuration
@ComponentScan(basePackages = {"com.mayikt.controller","com.mayikt.service"})
public class SpringMvcConfig extends WebMvcConfigurationSupport {
  ...
    // 1.手动注入拦截器到Spring中
    @Bean
    public TokenInterceptor tokenInterceptor() {
        return new TokenInterceptor();
    }
    // 2.添加拦截器
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(tokenInterceptor()).addPathPatterns("/**");// 拦截所有的请求
    }
}

注意:使用拦截器一定要关闭EnableWebMvc 否则拦截器不会生效。

fe0c8c794f12e027c1a84e16196f50faabf.jpg

进入这个@EnableWebMvc注解中,可知

a12f8f4883b72394e48a15e5b2dac6f3fc1.jpg

91fae8b90565a3b756066a9699fccde7e98.jpg

加入这个注解EnableWebMvc重复注入了WebMvcConfigurationSupport,会覆盖我们自定义的配置类

SpringMVC多线程异步处理

使用异步注解

@EnableAsync

@RequestMapping("/pay")
public String pay() {
    System.out.println(">>>1.开始调用pay<<<<<<< ThradName:" + Thread.currentThread().getName());
    payServie.pay();
    System.out.println(">>>3.结束调用pay<<<<<<< ThradName:" + Thread.currentThread().getName());
    return "pay";
}

使用异步Callable 带返回结果

@RequestMapping("/asyncPay")
@ResponseBody
public Callable<String> asyncPay() {
    System.out.println("1.开始执行payToMember>>>> name:" + Thread.currentThread().getName());
    Callable callable = new Callable<String>() {
        // 异步的对吧!
        public String call() throws Exception {
            // 耗时的时间都可以放到这个里面做 安卓里面
            String member = memberService.member();
            return member;
        }
    };
    System.out.println("4.<<<<结束执行payToMember>>> name:" + Thread.currentThread().getName());
    return callable;
}
@Component
public class MemberService {

    /**
     * member方法单独开启一个线程处理请求
     *
     * @return
     */
    public String member() {
        try {
            System.out.println("2.开始调用会员服务接口... name:" + Thread.currentThread().getName());
            Thread.sleep(5000);
            System.out.println("3.结束调用会员服务接口.. name:" + Thread.currentThread().getName());
        } catch (Exception e) {

        }
        return "member";
    }
}

面试题:

SpringMVC项目中使用到多线程?

肯定是有。

为什么要使用多线程?

提高我们响应的速度、异步执行。

在我们的Web中为什么要使用异步呢?

目的:快速响应给客户端,防止客户端请求等待的。单独开启一个线程处理

使用异步也有缺点:

  • 线程安全问题、不能及时拿到结果、消耗CPU
  • 能够让耗时的时间,交给单独线程处理 也能够拿到异步线程结果

本文参考

蚂蚁课堂

http://www.mayikt.com/

 

转载于:https://my.oschina.net/u/3995125/blog/3082102

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值