一.Servlet执行流程
如图,这是Servlet执行流程,要想实现Servlet,我们要先让普通类继承HttpServlet 这个抽象类 ,其实,HttpServlet还继承了GenericServlet 这个抽象类 ,而GenericServlet又实现了Servlet接口。那么这些抽象类和接口都有哪些作用呢?
1.Servlet接口用来定义Servlet的生命周期,它包含了以下方法:
init () 初始化方法,目的是创建出 Servlet 对象
getServletConfig () 获取 Servlet的配置信息
service (ServletRequest var1, ServletResponse var2) 进行Servlet服务
getServletInfo () 获取Servlet的运行信息
destroy () 销毁Servlet对象
2.GenericServlet这个抽象类实现了 Servlet 接口当中的除了service方法以外的所有方法。
3.HttpServlet实现 了Servlet接口当中的service方法,为了匹配http的请求方式,它根据http的请求方式将service方法的内容用不同的方法进行实现,比如doGet,doPost,doPut等。
4.普通类继承HttpServlet抽象类,并且重写 doGet、doPost等方法,进行更加具体的实现。

二.Tomcat执行流程
如图,右边的大方框相当于服务器,这里理解成电脑也可以,以下是Tomca的执行过程:
首先客户端的请求(比如http://ip:8080/xx/xx)先要打在网卡上,**网卡** 进行注册端口的操作(比如请求传过来8080就注册8080的端口)。
注册完端口请求就会发送给Socket,Socket的作用就是实现设备间的网络通信 ,所以这是Socket要打开输入流 InputStream,根据输入流解析 其中的数据(比如来源,请求地址,请求类型等信息,这些信息一般都位于"请求头"),得到请求地址和请求类型之后,把地址发送给Servlet容器(这里的地址以/my为例)。
Servlet容器根据这个地址找到了对应的Servlet对象 之后,找到/my对应的Servlet对象的地址,解析对象的代码,把对象里的请求类型(get或post,这里以get为例)发送给对象。
对象里的doGet方法此时用request接收 ,然后根据用户在方法内写下的具体行为,生成response ,把response打回到Socket当中,Socket此时打开输出流OutputStream。
然后输出内容,把响应返回给客户端。
Servlet容器由地址和Servlet对象构成 ,两者一一对应,是键值对,key值就是Servlet的访问路径,value值是Servlet 对象(由全路径名生成),底层是HashMap。

三.如何自定义实现Tomcat
如图,这是如果想自定义Tomcat并且想要实现的话,需要做的流程:
首先,Tomcat启动,先获取两样东西,一个是通过扫描项目文件夹下的所有Servlet文件以获取的类的全路径名 (Java反射用到过),二是获取到Servlet文件当中的@WebServlet 注解括号里的配置信息(Servlet 的访问路径) ,使用这两个东西来生成Servlet容器(本质是HashMap),key值就是Servlet的访问路径,value值是Servlet 对象(由全路径名生成),这个Servlet容器生成后等待发挥作用。
另一边,客户端通过前端发过来请求给服务器,打到Socket上,利用Socket打开输入流获取请求信息,然后创建HttpServletRequest类,将请求信息当中的所有内容都封装到request对象当中去。
这时刚才创建的Servlet容器要发挥作用了,利用请求的路径作为key值,判断是否访问Servlet容器当中的对象。
如果是的话,就根据request对象当中的请求方式调用 Servlet 对象当中的具体方法,返回具体的信息,如果不是的话,判断路径访问的是否是静态资源(如html,css,js等)。
不论是静态资源,还是因不是静态资源而返回的404,还是Servlet返回具体的信息 ,都会使系统创建 HttpServletResponse类,生成response对象,封装返回数据。
这些数据打到Socket上调用Socket 获取输出流,返回数据给客户端。
