ajax请求controller 返回modelandview_一次请求 SpringMVC 到底做了什么?

0x0 先看名词

  • DispactherServlet:SpringMVC 的心脏,所有的请求从这里进入,也从这里出去
  • HandlerAdapter:请求处理器
  • HandlerMapping:请求和处理对象间的映射关系,可以理解为 地址 /api 对应 @RequestMapping("/api")
  • doDispatch:SpringMVC 处理请求的方法
  • ModelAndView:视图响应对象,例如我们Controller返回一个字符串,都会被包装成它
  • ViewResolvers:视图解析器,解析响应结果为浏览器能识别的网页或者文件
  • ContentNegotiatingViewResolver:SpringMVC 提供的视图内容协商器,根据响应视图类型来判断使用哪个解析器来解析,是使 SpringMVC 支持多视图解析器的重要组件,官方说明:https://spring.io/blog/2013/06/03/content-negotiation-using-views

0x1 一个请求过来

请求进入 DispactherServlet 会被分配给 doDispatch ,所以直接断点 doDispatch 即可

4aca87f88dfa6bbc82c1431c6a1362d8.png

0x01 请求处理器

doDispatch 会匹配相应的 HandlerMapping (可以理解为你在 Controller 中写的方法),然后执行并拿到返回结果(也就是 ModelAndView)

cc3c49bfbf41155d4d45aa32d6207be4.png

0x02 视图解析器

DispactherServlet 会将ModelAndView交给 ViewResolvers(也就是常说的视图解析器) 解析处理。

ViewResolvers 中 ContentNegotiatingViewResolver(详见 0x0 解释)它去问所有的视图解析器:这个 ModelAndView 你们能解析的了吗?,如下图:

类:ContentNegotiatingViewResolver

fc268f08e8026c106db2dee023cabbc0.png

如何确定谁才是天选之子解析器?MediaType!按照顺序,第一个符合 MediaType 的解析器将被使用。

PS:比如你响应的是 text/html 文件,但是 text/html 解析器有两个,你想优先使用其中一个的话,你就得为该解析器设置 Order (详见 0x0 中官方说明)

b24b313cfa2ae1c5949b4abc355217c4.png
7dfa150ba4a0f741382366df681110bb.png


得到 ModelView 以后,视图解析器的任务就算完成了

0x03 合并模板

下一步跳转到 视图处理

b0bc7e6ac2cc9ad160e3ade5a2a75b51.png

进入 render 方法后,会执行 Prepares the view given the specified model, merging it with static ,通俗讲就是将我们 Request 域或者 Session域 中的值(比如说请求参数回显)和视图解析出来的 ModelAndView 进行合并,这也是为什么我们再模板中可以轻松获得各种作用域值的原因,继续往下看

7e0b6378e1eef706e868f80ecbb498cd.png

组装 ModelAndView

01187c504a97c93e02d82d1fdb8ade05.png

执行视图合并

d53ececd8169fae6c1fd9bd93e09a6dc.png
6e7502c6ee807a689de7b6fa92c7ac92.png

获取模板文件和语言信息

39cb7b1017cc6f97d8d659f527ac2968.png

将 ModelAndView 中的属性全部传递给 FreeMarker

ff382f9691299157b92951d1f3029185.png

最后一步生成 Html 并响应到浏览器

2fcd3f1e50bd273a2587436a700bda05.png

0x2 静态资源处理

SpringMVC 在视图处理器如果找不到合适的处理器的情况下,就会视该请求为静态资源请求并使用静态资源解析器解析该请求。

默认的静态资源目录如下,这也是为什么你将静态资源放在 resource 目录的时候不需要任何配置便可访问的原因

1b18f664daa6e3b639d3fba1c5340cea.png

如果本文对你有帮助,欢迎关注并点赞~ 任何问题请评论区或者公众号留言。

关注本人公众号,收获双倍快乐

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值