引言
都SpringMVC了为什么还要学Servlet?
今天面试一个工程师,tomcat、springmvc都懂,基础还不错,最后问了这个问题:SpringMVC、Tomcat是怎样完成一次Http请求的?
能回答说tomcat把请求分配给springmvc,具体业务逻辑由springmvc执行,听着有些含糊。
其实这个问题只是把各自独立的内容整合在一起问而已,就把面试者难住了。要回答这个问题并不难。
首先,我们来看看Tomcat、SpringMVC各自的定位和职责。
Tomcat和SpringMVC的职责
- Tomcat:The Apache Tomcat software is an open source implementation of the Java Servlet, JavaServer Pages, Java Expression Language and Java WebSocket technologies.
- SpringMVC:Spring推出的基于Servlet标准的MVC框架实现。
正是因为上面的定义,程序员经常把Tomcat是一个Servlet容器,其实Tomcat实现的功能比这个要更多一些。
由上面两个的职责描述,可以看出SpringMVC和Tomcat的结合点是Servlet。其实SpringMVC的DispatchServlet实现了HttpServlet,那么SpringMVC在Tomcat看来,其实就是一个Servlet。
Tomcat和Servlet的工作原理
Tomcat作为Servlet容器,当然也可以当作web服务器直接使用,负责把接收和返回http请求。
下面,我们通过一个更细致的时序图来看一下具体工作过程:从上图我们看出一个Http的具体处理流程:
- Web客户向Servlet容器(Tomcat)发出Http请求
- Servlet容器分析客户的请求信息
- Servlet容器创建一个HttpRequest对象,将客户请求的信息封装到这个对象中
- Servlet容器创建一个HttpResponse对象
- Servlet容器调用HttpServlet对象的service方法,把HttpRequest对象与HttpResponse对象作为参数传给 HttpServlet对象
- HttpServlet调用HttpRequest对象的有关方法,获取Http请求信息
- HttpServlet调用HttpResponse对象的有关方法,生成响应数据
- Servlet容器把HttpServlet的响应结果传给Web客户
Tomcat下Servlet的配置文件:web.xml
web.xml的作用是配置Http和Servlet之间的映射关系、filter、context参数等。这样通过这份约定的配置文件,Tomcat可以把Http请求映射到不同的Servlet实例上。所以,在Servlet时代的web.xml中,会有很多的项配置。
SpringMVC的改变
我们上面说过,SpringMVC也是Servlet的实现,只不过SpringMVC增加了一个DispatchServlet,所有的http请求都是映射到这个Servlet上,请求进入到这个Servlet中之后,就算进入到了框架之中了,由这个Servlet来统一的分配http请求到各个Controller,接下来的事情大家就清楚了。
=============================================================
转载者补充:
这是SpringMVC在web.xml中的配置。可以看出SpringMVC在Tomcat看来就是一个servlet,所有请求都交由这个Servlet处理。org.springframework.web.servlet.DispatcherServlet实现了HttpServlet
springmvc org.springframework.web.servlet.DispatcherServlet contextConfigLocation classpath:springmvc-servlet.xml springmvc /*
这个是Struts在web中的配置。同样可以看出Struts在Tomcat看来是一个Filter,所有的请求都会先交给这个Filter处理。org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter实现了javax.servlet.Filter。Tomcat内部应该是通过调用javax.servlet.Filter的方法(在StrutsPrepareAndExecuteFilter中实现的,实际就是将请求交由Struts了)
struts2 org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter struts2 /*
这个是Spring在web.xml中的配置。实际就是Tomcat在启动时,会触发这个Listener,然后这个Listener里就会执行Spring的初始化、bean的创建等操作。
org.springframework.web.context.ContextLoaderListener contextConfigLocation classpath:applicationContext.xml