java中MVC原理详解,SpringMVC运行原理,MVC的基本原理
SpringMVC运行原理,MVC的基本原理
按照上边的执行流程图,我们可以看出一个SpringMVC整体的一个执行轮廓,下面我们具体来分析下
首先服务器接收到一个请求,匹配并调用了我们的前端控制器(DispatcherServlet)也叫中央处理器的请求路径,在web.xml文件中配置,我们来看下配置文件
springmvc
org.springframework.web.servlet.DispatcherServlet
contextConfigLocation
classpath:springmvc.xml
1
springmvc
/
因为DispatcherServlet实际上是间接的继承了我们的HttpServlet,所以它就相当于一个Servlet,SpringMVC帮我们封装好的一个Servlet,下面是继承体系
所以说,当来了一个请求后,WEB容器将把请求交给我们的DispatcherServlet进行处理
DispatcherServlet接收到请求后,会把我们的请求信息交给HandlerMapping处理器映射器进行处理
HandlerMapping根据请求的URL信息去查找匹配的URL的Handler,如果查找成,并返回一个执行链,下面来看下底层执行代码
protected HandlerExecutionChain getHandler(HttpServletRequest request) throws Exception {
Iterator var2 = this.handlerMappings.iterator();
HandlerExecutionChain handler;
do {
if (!var2.hasNext()) {
return null;
}
HandlerMapping hm = (HandlerMapping)var2.next();
if (this.logger.isTraceEnabled()) {
this.logger.trace("Testing handler map [" + hm + "] in DispatcherServlet with name '" + this.getServletName() + "'");
}
handler = hm.getHandler(request);//根据request对象获取handler,获取到的话将返回一个对象,没有的话将返回null 有兴趣童鞋自行深入查看
} while(handler == null);//如果handler为null继续执行循环
return handler;
}
如果没有找到的话将执行以下代码
protected void noHandlerFound(HttpServletRequest request, HttpServletResponse response) throws Exception {
if (pageNotFoundLogger.isWarnEnabled()) {
pageNotFoundLogger.warn("No mapping found for HTTP request with URI [" + getRequestUri(request) + "] in DispatcherServlet with name '" + this.getServletName() + "'");
}
if (this.throwExceptionIfNoHandlerFound) {
ServletServerHttpRequest sshr = new ServletServerHttpRequest(request);
throw new NoHandlerFoundException(sshr.getMethod().name(), sshr.getServletRequest().getRequestURI(), sshr.getHeaders());
} else {
response.sendError(404);//响应404
}
}
找到成功的情况下,DispatcherServlet再次请求 处理器适配器(HandlerAdapter)调用相应的Handler 进行处理返回 ModelAndView 给 DispatcherServlet,底层代码,粗略看下即可,不是重点
protected void doDispatch(HttpServletRequest request, HttpServletResponse response) throwsException {
HttpServletRequest processedRequest=request;
HandlerExecutionChain mappedHandler= null;boolean multipartRequestParsed = false;
WebAsyncManager asyncManager=WebAsyncUtils.getAsyncManager(request);try{
ModelAndView mv= null;
Exception dispatchException= null;try{
processedRequest= this.checkMultipart(request);
multipartRequestParsed= processedRequest !=request;
mappedHandler= this.getHandler(processedRequest);if (mappedHandler == null || mappedHandler.getHandler() == null) {this.noHandlerFound(processedRequest, response);return;
}
HandlerAdapter ha= this.getHandlerAdapter(mappedHandler.getHandler());
String method=request.getMethod();boolean isGet = "GET".equals(method);if (isGet || "HEAD".equals(method)) {long lastModified =ha.getLastModified(request, mappedHandler.getHandler());if (this.logger.isDebugEnabled()) {this.logger.debug("Last-Modified value for [" + getRequestUri(request) + "] is: " +lastModified);
}if ((new ServletWebRequest(request, response)).checkNotModified(lastModified) &&isGet) {return;
}
}if (!mappedHandler.applyPreHandle(processedRequest, response)) {return;
}
mv=ha.handle(processedRequest, response, mappedHandler.getHandler()); //在这里边调用相应的Handler,并通过这个方法返回ModelAndModel给DispatcherServletif(asyncManager.isConcurrentHandlingStarted()) {return;
}this.applyDefaultViewName(request, mv);
mappedHandler.applyPostHandle(processedRequest, response, mv);
}catch(Exception var19) {
dispatchException=var19;
}this.processDispatchResult(processedRequest, response, mappedHandler, mv, dispatchException);
}catch(Exception var20) {this.triggerAfterCompletion(processedRequest, response, mappedHandler, var20);
}catch(Error var21) {this.triggerAfterCompletionWithError(processedRequest, response, mappedHandler, var21);
}finally{if(asyncManager.isConcurrentHandlingStarted()) {if (mappedHandler != null) {
mappedHandler.applyAfterConcurrentHandlingStarted(processedRequest, response);
}
}else if(multipartRequestParsed) {this.cleanupMultipart(processedRequest);
}
}
}
然后DispatcherServlet将ModelAndView请求对应的ViewResolver(视图解析器)解析视图,然后返回具体的View,底层实现
protected View resolveViewName(String viewName, Map model, Locale locale, HttpServletRequest request) throwsException {
Iterator var5= this.viewResolvers.iterator();
View view;do{if (!var5.hasNext()) {return null;
}
ViewResolver viewResolver=(ViewResolver)var5.next();
view=viewResolver.resolveViewName(viewName, locale);
}while(view == null);returnview;
}
DispatcherServlet对View视图进行渲染,也就是把模型数据填充到视图里边,底层执行代码
protected void render(ModelAndView mv, HttpServletRequest request, HttpServletResponse response) throwsException {
Locale locale= this.localeResolver.resolveLocale(request);
response.setLocale(locale);
View view;if(mv.isReference()) {
view= this.resolveViewName(mv.getViewName(), mv.getModelInternal(), locale, request);if (view == null) {throw new ServletException("Could not resolve view with name '" + mv.getViewName() + "' in servlet with name '" + this.getServletName() + "'");
}
}else{
view=mv.getView();if (view == null) {throw new ServletException("ModelAndView [" + mv + "] neither contains a view name nor a " + "View object in servlet with name '" + this.getServletName() + "'");
}
}if (this.logger.isDebugEnabled()) {this.logger.debug("Rendering view [" + view + "] in DispatcherServlet with name '" + this.getServletName() + "'");
}try{
view.render(mv.getModelInternal(), request, response);
}catch(Exception var7) {if (this.logger.isDebugEnabled()) {this.logger.debug("Error rendering view [" + view + "] in DispatcherServlet with name '" + this.getServletName() + "'", var7);
}throwvar7;
}
}
最后DispatcherServlet将视图传递给前台
PS:
Spring MVC核心组件:
1.DispatcherServlet(中央处理器):将请求转发给控制器
2.Controller(控制器):处理请求的控制器
3.HandlerMapping(映射处理器):负责映射中央处理器转发给Controller时的映射策略
4.ModelAndView:服务器返回数据以及视图层的封装类
5.ViewResolver(视图解析器):解析具体的视图
当用户发起请求后,执行DiapacherServlet,如果是JSP直接调用jsp页面.如果不是JSP,DiapacherServlet调用HandlerMapping判断请求URL是否合法,如果URL不存在报错,如果URL存在使用HandlerAdapter调用具体的HandlerMethod,当Handler执行完成后会返回ModelAndView,会被ViewResovler解析,调用具体的物理视图.
最终响应给客户端浏览器.
相关文章暂无相关文章
java中MVC原理详解,SpringMVC运行原理,MVC的基本原理相关推荐
- Java中JDBC连接数据库详解
今天动力节点java学院小编分享的是JDBC连接数据库的相关知识,希望通过看过此文,各位小伙伴对DBC连接数据库有所了解,下面就跟随小编一起来看看JDBC连接数据库的知识吧. 一.JDBC连接数据库概 ...
- 初级游戏外挂编程详解 windows运行原理+游戏辅助编程 游戏外挂编程
@TOC初级游戏外挂编程详解 windows运行原理+游戏辅助编程 游戏外挂编程 [1]什么是windows API Windows API 中文翻译过来就是windows应用程序接口(Applica ...
- Java中super关键字详解
Java中super关键字详解 super有什么用? super什么时候不可以省略呢? super在内存图中是如何存在的呢? super使用时的注意事项 super有什么用? (1)当子类中构造方法第 ...
- JAVA中的Random详解
JAVA中的Random详解 首先,在JDK自带的常用的random中有两个,这俩都是产生随机数的,不过一个是util下的random,另外一个是Math下的.我们分别介绍一下 util中的rando ...
- java中new关键字详解
java中new关键字详解 在java中我们可以经常使用new来创建一个对象,但是这对于初学者来说可能只会使用却不能理解new关键字和它的语法 new关键字的语法 注意使用前先导包,一般我们使用ide ...
- Java中的byte详解
Java中的byte详解 介绍 byte,即字节,由8位的二进制组成.在Java中,byte类型的数据是8位带符号的二进制数. 在计算机中,8位带符号二进制数的取值范围是[-128, 127],所以在 ...
- Java中Iterator迭代器详解
目录 一.Java中Iterator迭代器详解 1.为什么需要迭代器 2.迭代器长什么样子 3.如何使用迭代器 使用步骤: 代码演示: 迭代器可以简化为增强型for循环: 4.Iterator与Lis ...
- Java 中IO流详解(附实例代码/面试题)
Java I/O流详解 前言 一.I/O流是什么? 二.IO流分类: 1. 流程图: io流对象 2. io流的优缺点: 3. io 流Java中用途有哪些? 三.一些 io 实例 四.面试题: 前言 ...
- 1、Java中“并发编程”详解【voliate、synchronized、JMM内存模型、原子类操作Atomic..、CAS原理】
文章目录 1.对volatile 的理解? JMM(Java 内存模型) JMM模型的三大特性: 禁止指令排序 线程安全性保证 你在哪些地方用到过 volatile?单例 2.CAS 你知道吗?CAS ...
最新文章
- 模拟实现请求分页虚存页面替换算法_模拟卷二解答
- MATLAB获取一个目录中的所有文件
- raspberry pi 3B 树莓派 安装tensorflow
- Dom4J的基本使用
- MOS和三极管不同接法对应的性能比较
- jQuery事件3——trigger触发事件
- 2014年2月份第3周51Aspx源码发布详情
- activemq java 异步_异步消息处理机制之activeMQ应用实例
- 3D印花芭蕾舞鞋为舞者科学地保护双脚
- Selenium自动化测试-7.获取元素属性信息
- keil中断函数的写法_中断函数写法的比较
- Unity Shader-Decal贴花(SelfDecal,Alpha Blend,Mesh Decal,Projector,Deferred Decal)
- android sms 接收短信,Android SMS 短信操作
- CPU是沙子做的,凭什么卖那么贵?
- 有什么提升技术能力的网站
- 安装Tomcat详细步骤
- vue + echarts 实现乡镇地图
- 学理发是先去学校还是去理发店学基础知识
- 计算机名词解释剪切,剪切力名词解释
- 【读书】马克·李维《自由的孩子》摘录