8 个面试被问烂的 SpringMVC 过程

 

SpringMVC ,这个应该是国内面试必问题,网上有不少答案,其实背背就能够。但今天笔者带你们一块儿深刻浅出源码,看看他的原理。以期让印象更加深入,面试的时候游刃有余。web

Spring MVC 过程面试

先来张图:性能优化

 

 

代码位置:架构

com.interface21.web.servlet.DispatcherServlet#doService并发

(没错,就是 Spring 1.0 的代码,大道至简,如今的 Spring 通过 15 年的发展,已经太过臃肿,从学习角度来讲,interface 21 是最好的代码,不接受反驳)app

代码以下:分布式

1. 设置属性微服务

 
// 1. 设置属性 // Make web application context available request.setAttribute(WEB_APPLICATION_CONTEXT_ATTRIBUTE, getWebApplicationContext()); // Make locale resolver available request.setAttribute(LOCALE_RESOLVER_ATTRIBUTE, this.localeResolver); // Make theme resolver available request.setAttribute(THEME_RESOLVER_ATTRIBUTE, this.themeResolver);

2. 根据 Request 请求的 URL 获得对应的 handler 执行链,其实就是拦截器和 Controller 代理对象。高并发

 
// 2. 找 handler 返回执行链 HandlerExecutionChain mappedHandler = getHandler(request);

3. 获得 handler 的适配器源码分析

 
// This will throw an exception if no adapter is found // 3. 返回 handler 的适配器 HandlerAdapter ha = getHandlerAdapter(mappedHandler.getHandler());

关于这个适配器,做用究竟是啥呢?HandlerAdapter 注释写到:This interface is not intended for application developers. It is available to handlers who want to develop their own web workflow.

译:此接口不适用于应用程序开发人员。它适用于想要开发本身的Web工做流程的处理程序。

也就说说,若是你想要在处理 handler 以前作一些操做的话,可能须要这个,即适配一下这个 handler。例如 Spring 的测试程序作的那样:

 
public ModelAndView handle(HttpServletRequest request, HttpServletResponse response, Object delegate) throws IOException, ServletException { // 你可能须要 doSomething....... ((MyHandler) delegate).doSomething(request); return null; }

4. 循环执行 handler 的 pre 拦截器

 
// 4. 循环执行 handler 的 pre 拦截器 for (int i = 0; i < mappedHandler.getInterceptors().length; i++) { HandlerInterceptor interceptor = mappedHandler.getInterceptors()[i]; // pre 拦截器 if (!interceptor.preHandle(request, response, mappedHandler.getHandler())) { return; } }

这个没什么好讲的吧?

顺便在此给你们推荐一个Java架构方面的交流学习群:698581634,进群便可免费获取Java架构学习资料:里面有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系,群里必定有你须要的资料,你们赶忙加群吧。

5. 执行真正的 handler,并返回 ModelAndView(Handler 是个代理对象,可能会执行 AOP )

 
// 5. 执行真正的 handler,并返回 ModelAndView(Handler 是个代理对象,可能会执行 AOP ) ModelAndView mv = ha.handle(request, response, mappedHandler.getHandler());

6. 循环执行 handler 的 post 拦截器

 
// 6. 循环执行 handler 的 post 拦截器 for (int i = mappedHandler.getInterceptors().length - 1; i >=0 ; i--) { HandlerInterceptor interceptor = mappedHandler.getInterceptors()[i]; // post 拦截器 interceptor.postHandle(request, response, mappedHandler.getHandler()); }

7. 根据 ModelAndView 信息获得 View 实例

 
View view = null; if (mv.isReference()) { // We need to resolve this view name // 7. 根据 ModelAndView 信息获得 View 实例 view = this.viewResolver.resolveViewName(mv.getViewName(), locale); }

8. 渲染 View 返回

 
// 8. 渲染 View 返回 view.render(mv.getModel(), request, response);
相关文章
相关标签/搜索