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("<<
@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 否则拦截器不会生效。
进入这个@EnableWebMvc注解中,可知
加入这个注解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
@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
- 能够让耗时的时间,交给单独线程处理 也能够拿到异步线程结果
本文参考
蚂蚁课堂