SpringMVC 工作流程简述
💖The Begin💖点点关注,收藏不迷路💖
#mermaid-svg-xZqkXNPjG0SH5tMA {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-xZqkXNPjG0SH5tMA .error-icon{fill:#552222;}#mermaid-svg-xZqkXNPjG0SH5tMA .error-text{fill:#552222;stroke:#552222;}#mermaid-svg-xZqkXNPjG0SH5tMA .edge-thickness-normal{stroke-width:2px;}#mermaid-svg-xZqkXNPjG0SH5tMA .edge-thickness-thick{stroke-width:3.5px;}#mermaid-svg-xZqkXNPjG0SH5tMA .edge-pattern-solid{stroke-dasharray:0;}#mermaid-svg-xZqkXNPjG0SH5tMA .edge-pattern-dashed{stroke-dasharray:3;}#mermaid-svg-xZqkXNPjG0SH5tMA .edge-pattern-dotted{stroke-dasharray:2;}#mermaid-svg-xZqkXNPjG0SH5tMA .marker{fill:#333333;stroke:#333333;}#mermaid-svg-xZqkXNPjG0SH5tMA .marker.cross{stroke:#333333;}#mermaid-svg-xZqkXNPjG0SH5tMA svg{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;}#mermaid-svg-xZqkXNPjG0SH5tMA .label{font-family:"trebuchet ms",verdana,arial,sans-serif;color:#333;}#mermaid-svg-xZqkXNPjG0SH5tMA .cluster-label text{fill:#333;}#mermaid-svg-xZqkXNPjG0SH5tMA .cluster-label span{color:#333;}#mermaid-svg-xZqkXNPjG0SH5tMA .label text,#mermaid-svg-xZqkXNPjG0SH5tMA span{fill:#333;color:#333;}#mermaid-svg-xZqkXNPjG0SH5tMA .node rect,#mermaid-svg-xZqkXNPjG0SH5tMA .node circle,#mermaid-svg-xZqkXNPjG0SH5tMA .node ellipse,#mermaid-svg-xZqkXNPjG0SH5tMA .node polygon,#mermaid-svg-xZqkXNPjG0SH5tMA .node path{fill:#ECECFF;stroke:#9370DB;stroke-width:1px;}#mermaid-svg-xZqkXNPjG0SH5tMA .node .label{text-align:center;}#mermaid-svg-xZqkXNPjG0SH5tMA .node.clickable{cursor:pointer;}#mermaid-svg-xZqkXNPjG0SH5tMA .arrowheadPath{fill:#333333;}#mermaid-svg-xZqkXNPjG0SH5tMA .edgePath .path{stroke:#333333;stroke-width:2.0px;}#mermaid-svg-xZqkXNPjG0SH5tMA .flowchart-link{stroke:#333333;fill:none;}#mermaid-svg-xZqkXNPjG0SH5tMA .edgeLabel{background-color:#e8e8e8;text-align:center;}#mermaid-svg-xZqkXNPjG0SH5tMA .edgeLabel rect{opacity:0.5;background-color:#e8e8e8;fill:#e8e8e8;}#mermaid-svg-xZqkXNPjG0SH5tMA .cluster rect{fill:#ffffde;stroke:#aaaa33;stroke-width:1px;}#mermaid-svg-xZqkXNPjG0SH5tMA .cluster text{fill:#333;}#mermaid-svg-xZqkXNPjG0SH5tMA .cluster span{color:#333;}#mermaid-svg-xZqkXNPjG0SH5tMA div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:12px;background:hsl(80, 100%, 96.2745098039%);border:1px solid #aaaa33;border-radius:2px;pointer-events:none;z-index:100;}#mermaid-svg-xZqkXNPjG0SH5tMA :root{--mermaid-font-family:"trebuchet ms",verdana,arial,sans-serif;}
请求接收
请求解析
查找处理器
处理器适配
调用处理器
处理结果
结果传递
视图解析
视图渲染
响应用户
SpringMVC的工作流程可以通过以下几个步骤来展示:
1. 请求接收
- 用户发送HTTP请求到前端控制器DispatcherServlet。
2. 请求解析
- DispatcherServlet解析请求信息,包括URL、请求参数等。
3. 查找处理器
- 通过HandlerMapping组件根据请求URL找到对应的处理器(Controller)。
4. 处理器适配
- HandlerAdapter适配器检查找到的处理器是否适合当前请求,并准备调用。
5. 调用处理器
- DispatcherServlet通过HandlerAdapter调用处理器(Controller)执行相应的业务逻辑。
6. 处理结果
- 处理器执行完毕后,返回一个ModelAndView对象,包含视图名和模型数据。
7. 结果传递
- HandlerAdapter将ModelAndView对象返回给DispatcherServlet。
8. 视图解析
- DispatcherServlet通过ViewResolver组件解析ModelAndView中的视图名,找到对应的视图对象。
9. 视图渲染
- DispatcherServlet使用视图对象和模型数据进行页面渲染,生成最终的HTML或其他格式的响应内容。
10. 响应用户
- 将渲染后的页面或数据响应回客户端,完成整个请求-响应周期。
💖The End💖点点关注,收藏不迷路💖
版权归原作者 Seal^_^ 所有, 如有侵权,请联系我们删除。