zoukankan      html  css  js  c++  java
  • SpringMVC工作流程

    代码实现

    //处理模型数据方式一,将方法的返回值设置为ModelAndView
        @RequestMapping("test1")
        public ModelAndView test1(){
            //1、创建ModelAndView对象
            ModelAndView mav = new ModelAndView();
            //2、设置模型数据,最终会放到request域中
            mav.addObject("user","admin");
            //3、设置视图
            mav.setViewName("success");
            return mav;
        }
    
        /***
         * 处理模型数据方式二:方法的返回值乃是String类型,在方法的入参中传入Map、Model或者ModelMap
         * 不管将处理器方法的返回值设置为ModelAndView还是在方法的入参中传入Map、Model或者ModelMap
         * SpringMVC都会转换为一个ModelAndView
         */
        @RequestMapping("/test2")
        public String test2(Map<String,Object> map){
            //向Map中添加模型数据,最终会自动放到request域中
            map.put("user",new User(1,"张三"));
            return "success";
        }
    

    工作流程

    1、用户发送请求至前端控制器DispatcherServlet。
    2、DispatcherServlet收到请求调用HandlerMapping处理器映射器。
    3、处理器映射器找到具体的处理器(可以根据xml配置、注解进行查找),生成处理器对象及处理器拦截器(如果有则生成)一并返回给DispatcherServlet。
    4、 DispatcherServlet调用HandlerAdapter处理器适配器。
    5、HandlerAdapter经过适配调用具体的处理器(Controller,也叫后端控制器)。
    6、Controller执行完成返回ModelAndView。
    7、HandlerAdapter将controller执行结果ModelAndView返回给DispatcherServlet。
    8、DispatcherServlet将ModelAndView传给ViewReslover视图解析器。
    9、ViewReslover解析后返回具体View.
    10、DispatcherServlet根据View进行渲染视图(即将模型数据填充至视图中)。 
    11、DispatcherServlet响应用户。
    

  • 相关阅读:
    Charles:rewrite重写功能
    Vue中provide和inject 用法
    vue中install方法
    vue自定义组件(通过Vue.use()来使用)即install的使用
    Eelectron 中的remote模块
    理解Vue中的Render渲染函数
    Vue.js中this.$nextTick()的使用
    postman请求本地接口Error: connect ECONNREFUSED 127.0.0.1:8083
    1016 Phone Bills (25 分)
    CF842E Nikita and game
  • 原文地址:https://www.cnblogs.com/shaoyu/p/12460927.html
Copyright © 2011-2022 走看看