• Spring MVC 的执行流程


     

    (一)核心流程

     

    具体步骤:

    第一步:发起请求到前端控制器(DispatcherServlet)

    第二步:前端控制器请求HandlerMapping查找 Handler (可以根据xml配置、注解进行查找)

    第三步:处理器映射器HandlerMapping向前端控制器返回Handler,HandlerMapping会把请求映射为HandlerExecutionChain对象(包含一个Handler处理器(页面控制器)对象,多个HandlerInterceptor拦截器对象),通过这种策略模式,很容易添加新的映射策略

    第四步:前端控制器调用处理器适配器去执行Handler

    第五步:处理器适配器HandlerAdapter将会根据适配的结果去执行Handler

    第六步:Handler执行完成给适配器返回ModelAndView

    第七步:处理器适配器向前端控制器返回ModelAndView (ModelAndView是springmvc框架的一个底层对象,包括 Model和view)

    第八步:前端控制器请求视图解析器去进行视图解析 (根据逻辑视图名解析成真正的视图(jsp)),通过这种策略很容易更换其他视图技术,只需要更改视图解析器即可

    第九步:视图解析器向前端控制器返回View

    第十步:前端控制器进行视图渲染 (视图渲染将模型数据(在ModelAndView对象中)填充到request域)

    第十一步:前端控制器向用户响应结果

    (二) 核心开发步骤

    1、  DispatcherServlet 在 web.xml 中的部署描述,从而拦截请求到 Spring Web MVC

    2、  HandlerMapping 的配置,从而将请求映射到处理器

    3、  HandlerAdapter 的配置,从而支持多种类型的处理器

    注:处理器映射求和适配器使用纾解的话包含在了注解驱动中,不需要在单独配置

    4、  ViewResolver 的配置,从而将逻辑视图名解析为具体视图技术

    5、  处理器(页面控制器)的配置,从而进行功能处理 

    View是一个接口,实现类支持不同的View类型(jsp、freemarker、pdf...)

  • 相关阅读:
    Flask基础
    Scrapy框架(持久化,去重,深度控制,cookie)
    scrapy框架 简易整理
    BeautifulSoup 模块
    requests模块
    复习第三天
    在Django中使用原生Sql
    ajax跨域简单请求和复杂请求
    复习第二天
    IOS
  • 原文地址:https://www.cnblogs.com/xiaobaizhang/p/8503945.html
Copyright © 2020-2023  润新知