Http協(xié)議&Servlet
Http協(xié)議
- 什么是協(xié)議
雙方在交互、通訊的時候, 遵守的一種規(guī)范、規(guī)則。
- http協(xié)議
針對網(wǎng)絡上的客戶端 與 服務器端在執(zhí)行http請求的時候,遵守的一種規(guī)范。 其實就是規(guī)定了客戶端在訪問服務器端的時候,要帶上哪些東西, 服務器端返回數(shù)據(jù)的時候,也要帶上什么東西。
-
版本
1.0
請求數(shù)據(jù),服務器返回后, 將會斷開連接1.1
請求數(shù)據(jù),服務器返回后, 連接還會保持著。 除非服務器 | 客戶端 關掉。 有一定的時間限制,如果都空著這個連接,那么后面會自己斷掉。
演示客戶端 如何 與服務器端通訊。
在地址欄中鍵入網(wǎng)絡地址 回車 或者是平常注冊的時候,點擊了注冊按鈕 , 瀏覽器都能顯示出來一些東西。那么背地里到底瀏覽器和服務器是怎么通訊。 它們都傳輸了哪些數(shù)據(jù)。
安裝抓包工具 HttpWatch (IE插件)
打開tomcat. 輸入localhost:8080 打開首頁
在首頁上找到Example 字樣
6.x 和 7.x 的文檔頁面有所不同,但是只要找到example就能夠找到例子工程
- 選擇 servlet 例子 ---> Request Parameter

接著點擊Request Parameters 的 Execute超鏈接

執(zhí)行tomcat的例子,然后查看瀏覽器和 tomcat服務器的對接細節(jié)

Http請求數(shù)據(jù)解釋
請求的數(shù)據(jù)里面包含三個部分內(nèi)容 : 請求行 、 請求頭 、請求體
-
請求行
POST /examples/servlets/servlet/RequestParamExample HTTP/1.1 POST : 請求方式 ,以post去提交數(shù)據(jù) /examples/servlets/servlet/RequestParamExample 請求的地址路徑 , 就是要訪問哪個地方。 HTTP/1.1 協(xié)議版本 -
請求頭
Accept: application/x-ms-application, image/jpeg, application/xaml+xml, image/gif, image/pjpeg, application/x-ms-xbap, */* Referer: http://localhost:8080/examples/servlets/servlet/RequestParamExample Accept-Language: zh-CN User-Agent: Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0C; .NET4.0E) Content-Type: application/x-www-form-urlencoded Accept-Encoding: gzip, deflate Host: localhost:8080 Content-Length: 31 Connection: Keep-Alive Cache-Control: no-cache Accept: 客戶端向服務器端表示,我能支持什么類型的數(shù)據(jù)。 Referer : 真正請求的地址路徑,全路徑 Accept-Language: 支持語言格式 User-Agent: 用戶代理 向服務器表明,當前來訪的客戶端信息。 Content-Type: 提交的數(shù)據(jù)類型。經(jīng)過urlencoding編碼的form表單的數(shù)據(jù) Accept-Encoding: gzip, deflate : 壓縮算法 。 Host : 主機地址 Content-Length: 數(shù)據(jù)長度 Connection : Keep-Alive 保持連接 Cache-Control : 對緩存的操作 請求體
瀏覽器真正發(fā)送給服務器的數(shù)據(jù)
發(fā)送的數(shù)據(jù)呈現(xiàn)的是key=value ,如果存在多個數(shù)據(jù),那么使用 &
firstname=zhang&lastname=sansan
Http響應數(shù)據(jù)解析
請求的數(shù)據(jù)里面包含三個部分內(nèi)容 : 響應行 、 響應頭 、響應體
HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
Content-Type: text/html;charset=ISO-8859-1
Content-Length: 673
Date: Fri, 17 Feb 2017 02:53:02 GMT
...這里還有很多數(shù)據(jù)...
-
響應行
HTTP/1.1 200 OK 協(xié)議版本 狀態(tài)碼 咱們這次交互到底是什么樣結果的一個code. 200 : 成功,正常處理,得到數(shù)據(jù)。 403 : for bidden 拒絕 404 : Not Found 500 : 服務器異常 OK 對應前面的狀態(tài)碼 -
響應頭
Server: 服務器是哪一種類型。 Tomcat Content-Type : 服務器返回給客戶端你的內(nèi)容類型 Content-Length : 返回的數(shù)據(jù)長度 Date : 通訊的日期,響應的時間
Get 和 Post請求區(qū)別

-
post
1. 數(shù)據(jù)是以流的方式寫過去,不會在地址欄上面顯示。 現(xiàn)在一般提交數(shù)據(jù)到服務器使用的都是POST 2. 以流的方式寫數(shù)據(jù),所以數(shù)據(jù)沒有大小限制。 -
get
1. 會在地址欄后面拼接數(shù)據(jù),所以有安全隱患。 一般從服務器獲取數(shù)據(jù),并且客戶端也不用提交上面數(shù)據(jù)的時候,可以使用GET 2. 能夠帶的數(shù)據(jù)有限, 1kb大小
Web資源
在http協(xié)議當中,規(guī)定了請求和響應雙方, 客戶端和服務器端。與web相關的資源。
有兩種分類
-
靜態(tài)資源
html 、 js、 css
-
動態(tài)資源
servlet/jsp
Servlet
- servlet是什么?
其實就是一個java程序,運行在我們的web服務器上,用于接收和響應 客戶端的http請求。
更多的是配合動態(tài)資源來做。 當然靜態(tài)資源也需要使用到servlet,只不過是Tomcat里面已經(jīng)定義好了一個 DefaultServlet
Hello Servlet
得寫一個Web工程 , 要有一個服務器。
-
測試運行Web工程
1. 新建一個類, 實現(xiàn)Servlet接口 2. 配置Servlet , 用意: 告訴服務器,我們的應用有這么些個servlet。 在webContent/WEB-INF/web.xml里面寫上以下內(nèi)容。 <!-- 向tomcat報告, 我這個應用里面有這個servlet, 名字叫做HelloServlet , 具體的路徑是com.itheima.servlet.HelloServlet --> <servlet> <servlet-name>HelloServlet</servlet-name> <servlet-class>com.itheima.servlet.HelloServlet</servlet-class> </servlet> <!-- 注冊servlet的映射。 servletName : 找到上面注冊的具體servlet, url-pattern: 在地址欄上的path 一定要以/打頭 --> <servlet-mapping> <servlet-name>HelloServlet</servlet-name> <url-pattern>/a</url-pattern> </servlet-mapping> 3. 在地址欄上輸入 http://localhost:8080/項目名稱/a
Servlet執(zhí)行過程

Servlet的通用寫法
Servlet (接口)
|
|
GenericServlet
|
|
HttpServlet (用于處理http的請求)
- 定義一個類,繼承HttpServlet 復寫doGet 和 doPost

Servlet的生命周期
- 生命周期
從創(chuàng)建到銷毀的一段時間
- 生命周期方法
從創(chuàng)建到銷毀,所調(diào)用的那些方法。
-
init方法
在創(chuàng)建該servlet的實例時,就執(zhí)行該方法。 一個servlet只會初始化一次, init方法只會執(zhí)行一次 默認情況下是 : 初次訪問該servlet,才會創(chuàng)建實例。 -
service方法
只要客戶端來了一個請求,那么就執(zhí)行這個方法了。 該方法可以被執(zhí)行很多次。 一次請求,對應一次service方法的調(diào)用 destroy方法
servlet銷毀的時候,就會執(zhí)行該方法
1. 該項目從tomcat的里面移除。
2. 正常關閉tomcat就會執(zhí)行 shutdown.bat
doGet 和 doPost不算生命周期方法,所謂的生命周期方法是指,從對象的創(chuàng)建到銷毀一定會執(zhí)行的方法, 但是這兩個方法,不一定會執(zhí)行。
讓Servlet創(chuàng)建實例的時機 提前。
默認情況下,只有在初次訪問servlet的時候,才會執(zhí)行init方法。 有的時候,我們可能需要在這個方法里面執(zhí)行一些初始化工作,甚至是做一些比較耗時的邏輯。
那么這個時候,初次訪問,可能會在init方法中逗留太久的時間。 那么有沒有方法可以讓這個初始化的時機提前一點。
在配置的時候, 使用load-on-startup元素來指定, 給定的數(shù)字越小,啟動的時機就越早。 一般不寫負數(shù), 從2開始即可。
<servlet>
<servlet-name>HelloServlet04</servlet-name>
<servlet-class>com.itheima.servlet.HelloServlet04</servlet-class>
<load-on-startup>2</load-on-startup>
</servlet>
ServletConfig
Servlet的配置,通過這個對象,可以獲取servlet在配置的時候一些信息
先說 , 在寫怎么用, 最后說有什么用。
//1. 得到servlet配置對象 專門用于在配置servlet的信息
ServletConfig config = getServletConfig();
//獲取到的是配置servlet里面servlet-name 的文本內(nèi)容
String servletName = config.getServletName();
System.out.println("servletName="+servletName);
//2、。 可以獲取具體的某一個參數(shù)。
String address = config.getInitParameter("address");
System.out.println("address="+address);
//3.獲取所有的參數(shù)名稱
Enumeration<String> names = config.getInitParameterNames();
//遍歷取出所有的參數(shù)名稱
while (names.hasMoreElements()) {
String key = (String) names.nextElement();
String value = config.getInitParameter(key);
System.out.println("key==="+key + " value="+value);
}
為什么需要有這個ServletConfig
未來我們自己開發(fā)的一些應用,使用到了一些技術,或者一些代碼,我們不會。 但是有人寫出來了。它的代碼放置在了自己的servlet類里面。
剛好這個servlet 里面需要一個數(shù)字或者叫做變量值。 但是這個值不能是固定了。 所以要求使用到這個servlet的公司,在注冊servlet的時候,必須要在web.xml里面,聲明init-params
在開發(fā)當中比較少用。
剛才的這個實驗, 希望基礎好或者感興趣的同學,回去自己做一下。
總結
-
Http協(xié)議
1. 使用HttpWacht 抓包看一看http請求背后的細節(jié)。 2. 基本了解 請求和響應的數(shù)據(jù)內(nèi)容 請求行、 請求頭 、請求體 響應行、響應頭、響應體 3. Get和Post的區(qū)別 -
Servlet【重點】
1. 會使用簡單的servlet 1.寫一個類,實現(xiàn)接口Servlet 2. 配置Servlet 3. 會訪問Setvlet 2. Servlet的生命周期 init 一次 創(chuàng)建對象 默認初次訪問就會調(diào)用或者可以通過配置,讓它提前 load-on-startup service 多次,一次請求對應一次service destory 一次 銷毀的時候 從服務器移除 或者 正常關閉服務器 3. ServletConfig 獲取配置的信息, params