一·web
1。web是一種網站服務器,C/S架構,比較流行的Apache,Nginx,IIS。客戶能夠去服務器請求資
資源。
2.使用http協議,服務器html或者xml格式文件,客戶瀏覽器訪問資源(url)。
3.過程包括服務器套接字監聽直到和客戶套接字建立連接,客戶請求資源(獲得資源方式,資源位置url),服務器響應把資源按要求發送回客戶。
二·http
1.http超文本傳輸協議,應用層協議,基于tcp/ip協議。
2.http監聽tcp/80端口。
3.http事務大體過程。
1.一般客戶使用瀏覽器,輸入網址,要得到服務器IP地址,先要查看瀏覽器緩 存(緩存時間TTL定義),沒有就去查看本地hosts文件,etc/named.conf中 定義的域,還沒有查看自己設置的DNS服務器緩存,再沒有DNS服務器去給你 遞歸去。
2.tcp3次握手,建立連接。
3.客戶發送請求,順便說下請求消息報文的大體結構。
a.請求行包括請求方法一般用GET,URL字段,http版本。例如GET /index.html HTTP/1.1。
b.請求頭部,附加的一些信息。
Host接受請求的服務器地址,可以是IP:端口號,也可以是域名
User-Agent發送請求的應用程序名稱
Connection指定與連接相關的屬性,如Connection:Keep-Alive
Accept-Charset通知服務端可以發送的編碼格式
Accept-Encoding通知服務端可以發送的數據壓縮格式
Accept-Language通知服務端可以發送的語言格式
4.接收請求,順便說下接收多處理模塊MPM。
一般服務器都是高并發響應,keep-alive特性使得一次連接,能 多個請求,要適當用keep時間和資源請求數量坐下限定。
prefork一個進程處理一個請求,預先多個進程是謂進程池。
worker多個進程一個進程生成多個線程,一個線程處理一個請求,預 先多個線程。
event多個進程一個進程處理多個請求,預先多個進程。
5.響應報文
a.狀態行,例如HTTP//1.1 200 OK
包含版本號,狀態碼。
狀態碼大體如下
100-199請求過程狀態。
200-299接收請求和處理過程狀態,如200接收處理都OK
300-399詳細請求,如301資源位置變化,307資源位置臨時 變化
400-499客戶錯誤,如401未經授權,404找不到主機。
500-599服務端錯誤,如500服務器錯誤,503不接受請求
b.響應頭部,附加好多信息,如下
應答頭 | 說明 |
Allow | 服務器支持哪些請求方法(如GET、POST等)。 |
Content-Encoding | 文檔的編碼(Encode)方法。只有在解碼之后才可以得到Content-Type頭指定的內容類型。利用gzip壓縮文檔能夠顯著地減少HTML文檔的下載時間。Java的GZIPOutputStream可以很方便地進行gzip壓縮,但只有Unix上的 Netscape和Windows上的IE 4、IE 5才支持它。因此,Servlet應該通過查看Accept-Encoding頭(即request.getHeader("Accept- Encoding"))檢查瀏覽器是否支持gzip,為支持gzip的瀏覽器返回經gzip壓縮的HTML頁面,為其他瀏覽器返回普通頁面。 |
Content-Length | 表示內容長度。只有當瀏覽器使用持久HTTP連接時才需要這個數據。如果你想要利用持久連接的優勢,可以把輸出文檔寫入 ByteArrayOutputStram,完成后查看其大小,然后把該值放入Content-Length頭,最后通過 byteArrayStream.writeTo(response.getOutputStream()發送內容。 |
Content-Type | 表示后面的文檔屬于什么MIME類型。Servlet默認為text/plain,但通常需要顯式地指定為text/html。由于經常要設置Content-Type,因此HttpServletResponse提供了一個專用的方法setContentTyep。 |
Date | 當前的GMT時間。你可以用setDateHeader來設置這個頭以避免轉換時間格式的麻煩。 |
Expires | 應該在什么時候認為文檔已經過期,從而不再緩存它? |
Last-Modified | 文檔的最后改動時間。客戶可以通過If-Modified-Since請求頭提供一個日期,該請求將被視為一個條件 GET,只有改動時間遲于指定時間的文檔才會返回,否則返回一個304(Not Modified)狀態。Last-Modified也可用setDateHeader方法來設置。 |
Location | 表示客戶應當到哪里去提取文檔。Location通常不是直接設置的,而是通過HttpServletResponse的sendRedirect方法,該方法同時設置狀態代碼為302。 |
Refresh | 表示瀏覽器應該在多少時間之后刷新文檔,以秒計。除了刷新當前文檔之外,你還可以通過setHeader("Refresh", "5; URL=http://host/path")讓瀏覽器讀取指定的頁面。 注意這種功能通常是通過設置HTML頁面HEAD區的<META HTTP-EQUIV="Refresh" CONTENT="5;URL=http://host/path">實現,這是因為,自動刷新或重定向對于那些不能使用CGI或Servlet的 HTML編寫者十分重要。但是,對于Servlet來說,直接設置Refresh頭更加方便。 注意Refresh的意義是“N秒之后刷新本頁面或訪問指定頁面”,而不是“每隔N秒刷新本頁面或訪問指定頁面”。因此,連續刷新要求每次都發送一個Refresh頭,而發送204狀態代碼則可以阻止瀏覽器繼續刷新,不管是使用Refresh頭還是<META HTTP-EQUIV="Refresh" …>。 注意Refresh頭不屬于HTTP 1.1正式規范的一部分,而是一個擴展,但Netscape和IE都支持它。 |
Server | 服務器名字。Servlet一般不設置這個值,而是由Web服務器自己設置。 |
Set-Cookie | 設置和頁面關聯的Cookie。Servlet不應使用response.setHeader("Set-Cookie", …),而是應使用HttpServletResponse提供的專用方法addCookie。參見下文有關Cookie設置的討論。 |
WWW-Authenticate | 客戶應該在Authorization頭中提供什么類型的授權信息?在包含401(Unauthorized)狀態行的應答中這個頭是必需的。例如,response.setHeader("WWW-Authenticate", "BASIC realm=\"executives\"")。 注意Servlet一般不進行這方面的處理,而是讓Web服務器的專門機制來控制受密碼保護頁面的訪問(例如.htaccess)。 |
6.響應正文
響應過程和數據讀取存數也有好多內容的,下回分解吧。
原創文章,作者:藍色深空,如若轉載,請注明出處:http://www.www58058.com/6036