哪有什麼天生王者,不過是一步一個腳印
轉載自公眾號java團長
前言
Tomcat,這隻3腳貓,大學的時候就認識了,直到現在工作中,也常會和它打交道。這是一隻神奇的貓,今天讓我來抽象你,實現你!
Tomcat
Write MyTomcat
Tomcat是非常流行的Web Server,它還是一個滿足Servlet規範的容器。那麼想一想,Tomcat和我們的Web應用是什麼關係?
從感性上來說,我們一般需要把Web應用打成WAR包部署到Tomcat中,在我們的Web應用中,我們要指明URL被哪個類的哪個方法所處理(不論是原始的Servlet開發,還是現在流行的Spring MVC都必須指明)。
由於我們的Web應用是執行在Tomcat中,那麼顯然,請求必定是先到達Tomcat的。Tomcat對於請求實際上會進行下面的處理:
第一:提供Socket服務
Tomcat的啟動,必然是Socket服務,只不過它支援HTTP協議而已!
這裡其實可以擴充套件思考下,Tomcat既然是基於Socket,那麼是基於BIO or NIO or AIO呢?
第二:進行請求的分發
要知道一個Tomcat可以為多個Web應用提供服務,那麼很顯然,Tomcat可以把URL下發到不同的Web應用。
第三:需要把請求和響應封裝成request/response
我們在Web應用這一層,可從來沒有封裝過request/response的,我們都是直接使用的,這就是因為Tomcat已經為你做好了!
話不多說,先來看一眼工程截圖:
工程結構
MyRequest
封裝請求物件
這裡,你可以清楚的看到,我們通過輸入流,對HTTP協議進行解析,拿到了HTTP請求頭的方法以及URL。
MyResponse
封裝響應物件
基於HTTP協議的格式進行輸出寫入。
MyServlet
提供Servlet
前文說Tomcat是滿足Servlet規範的容器,那麼自然Tomcat需要提供API。這裡你看到了Servlet常見的doGet/doPost/service方法。
FindGirlServlet和HelloWorldServlet
FindGirlServlet
HelloWorldServlet
提供這2個具體的Servlet實現,只是為了後續的測試!
ServletMapping和ServletMappingConfig
servlet配置
servlet配置
你應該有些感覺了吧?
我們在servlet開發中,會在web.xml中通過<servlet></servlet>和<servlet-mapping></servlet-mapping>來進行指定哪個URL交給哪個servlet進行處理。
MyTomcat
start方法
dispatch
這裡,你能夠看到Tomcat的處理流程:把URL對應處理的Servlet關係形成,解析HTTP協議,封裝請求/響應物件,利用反射例項化具體的Servlet進行處理即可。
Test MyTomcat
running!
Ok,MyTomcat is so urgly,but i like it!