无XML整合
1.根据Serlvet3-1规范,可以动态的注册@WebServlet、@WebFilter、@WebListener
以WebServlet为例,这样就可以不用写servlet的xml配置了。spring利用这个特性完成无配置的springmvc整合。
public class MySpringServletContainerInitializer extends ServletContainerInitializer{
@Override
public void onStartup(Set<Class<?>> webAppInitializerClasses, ServletContext servletContext) throws ServletException {
// 通过servletContext动态添加Servlet
servletContext.addServlet("spiServlet", new HttpServlet() {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
resp.getWriter().write("spiServlet--doGet");
}
}).addMapping("/spiServlet.do");
}
- a.外置Tomcat启动的时候通过SPI 找到我们应用中的/METAINF/service/javax.servlet.ServletContainerInitializer
- b.调用SpringServletContainerInitializer.onStartUp(),@HandlesTypes(WebApplicationInitializer.class) 会找到所有实现WebApplicationInitializer接口的类,传入onStartUp方法,所有的实现类会生成spring的父子容器,DispatcherServlet,让所有的请求都由DispatcherServlet处理。ContextLoaderListener放入ServletContext,到时tomcat就会调用contextInitialized方法。
3.初始化ContextLoaderListener,contextInitialized调用父容器的refresh方法并把父容器servlet放入上下文。
4.初始化DispatcherServlet,tomcat会帮我们调用DispatcherServlet#init(),这个方法会获取到之前的父容器,并将现在的子容器设置父容器,注入子容器的监听器并调用refresh方法,执行完后,子容器的监听器就会收到事件
5.事件处理会初始化解析器、web上下文、主题解析器、HandlerMapping、HandlerAdapters、异常解析器对象、ViewResolvers处理器。为springmcv后续请求做准备。
请求流程处理
1.前端处理器 DispatcherServlet
接受所有请求,分发到各个控制器
2.处理器映射器 HandlerMapping
匹配请求的url,匹配上了返回Handler处理器(处理器和处理器拦截器拦截器),即controller里面的方法和定义的拦截器
3.处理器适配器 HandlerAdapter
负责调用Handler-具体的方法- 返回视图的名字 Handler将它封装到ModelAndView(封装视图名,request域的数据)
4.处理器(后端控制器) Handler
controller里面的方法,如果返回responsebody,则直接返回json数据,不走视图逻辑
5.视图解析器 ViewReslover
根据ModelAndView里面的视图名地址去找到具体的jsp封装在View对象中
6.view视图
进行视图渲染(将jsp转换成html内容 --这是Servlet容器的事情了) 最终response到的客户端