為了照顧沒(méi)學(xué)過(guò)Java Socket的初學(xué)者,或者說(shuō)捋一捋Android開(kāi)發(fā)中涉及到的網(wǎng)絡(luò)協(xié)議相關(guān)的概念,畢竟面試的時(shí)候,面試官來(lái)了句給我說(shuō)下網(wǎng)絡(luò)協(xié)議有幾層?那么IP協(xié)議在哪層?Socket是什么鬼?分哪幾種?TCP和UDP協(xié)議又在哪層?有什么區(qū)別...嗯,這...所以學(xué)習(xí)本節(jié)概念性的理論還是很有必要的!那么話不多說(shuō),開(kāi)始本節(jié)內(nèi)容~
當(dāng)然,我們不是專業(yè)搞網(wǎng)絡(luò)工程的,只要知道有哪些層,大概是拿來(lái)干嘛的就可以了!
OSI七層網(wǎng)絡(luò)模型(從下往上):
- 物理層(Physical):設(shè)備之間的數(shù)據(jù)通信提供傳輸媒體及互連設(shè)備,為數(shù)據(jù)傳輸提供可靠的環(huán)境。可以理解為網(wǎng)絡(luò)傳輸?shù)奈锢砻襟w部分,比如網(wǎng)卡,網(wǎng)線,集線器,中繼器,調(diào)制解調(diào)器等!在這一層,數(shù)據(jù)還沒(méi)有被組織,僅作為原始的位流或電氣電壓處理,這一層的單位是:bit比特
- 數(shù)據(jù)鏈路層(Datalink):可以理解為數(shù)據(jù)通道,主要功能是如何在不可靠的物理線路上進(jìn)行數(shù)據(jù)的可靠傳遞,改層作用包括:物理地址尋址,數(shù)據(jù)的成幀,流量控制,數(shù)據(jù)檢錯(cuò)以及重發(fā)等!另外這個(gè)數(shù)據(jù)鏈路指的是:物理層要為終端設(shè)備間的數(shù)據(jù)通信提供傳輸媒體及其連接。媒體是長(zhǎng)期的,連接是有生存期的。在連接生存期內(nèi),收發(fā)兩端可以進(jìn)行不等的一次或多次數(shù)據(jù)通信。每次通信都要經(jīng)過(guò)建立通信聯(lián)絡(luò)和拆除通信聯(lián)絡(luò)兩過(guò)程!這種建立起來(lái)的數(shù)據(jù)收發(fā)關(guān)系~該層的設(shè)備有:網(wǎng)卡,網(wǎng)橋,網(wǎng)路交換機(jī),另外該層的單位為:幀
- 網(wǎng)絡(luò)層(Network):主要功能是將網(wǎng)絡(luò)地址翻譯成對(duì)應(yīng)的物理地址,并決定如何將數(shù)據(jù)從發(fā)送方路由到接收方,所謂的路由與尋徑:一臺(tái)終端可能需要與多臺(tái)終端通信,這樣就產(chǎn)生的了把任意兩臺(tái)終端設(shè)備數(shù)據(jù)鏈接起來(lái)的問(wèn)題!簡(jiǎn)單點(diǎn)說(shuō)就是:建立網(wǎng)絡(luò)連接和為上層提供服務(wù)!該層的設(shè)備有:路由!該層的單位為:數(shù)據(jù)包,另外IP協(xié)議就在這一層!
- 傳輸層(Transport):向上面的應(yīng)用層提供通信服務(wù),面向通信部分的最高層,同時(shí)也是用戶功能中的最低層。接收會(huì)話層數(shù)據(jù),在必要時(shí)將數(shù)據(jù)進(jìn)行分割,并將這些數(shù)據(jù)交給網(wǎng)絡(luò)層,并且保證這些數(shù)據(jù)段有效的到達(dá)對(duì)端!所以這層的單位是:數(shù)據(jù)段;而這層有兩個(gè)很重要的協(xié)議就是:TCP傳輸控制協(xié)議與UDP用戶數(shù)據(jù)報(bào)協(xié)議,這也是本章節(jié)核心講解的部分!
- 會(huì)話層(Session):負(fù)責(zé)在網(wǎng)絡(luò)中的兩節(jié)點(diǎn)之間建立、維持和終止通信。建立通信鏈接,保持會(huì)話過(guò)程通信鏈接的暢通,同步兩個(gè)節(jié)點(diǎn)之間的對(duì)話,決定通信是否被中斷以及通信中斷時(shí)決定從何處重新發(fā)送,即不同機(jī)器上的用戶之間會(huì)話的建立及管理!
- 表示層(Presentation):對(duì)來(lái)自應(yīng)用層的命令和數(shù)據(jù)進(jìn)行解釋,對(duì)各種語(yǔ)法賦予相應(yīng)的含義,并按照一定的格式傳送給會(huì)話層。其主要功能是"處理用戶信息的表示問(wèn)題,如編碼、數(shù)據(jù)格式轉(zhuǎn)換和加密解密,壓縮解壓縮"等
- 應(yīng)用層(Application):OSI參考模型的最高層,為用戶的應(yīng)用程序提供網(wǎng)絡(luò)服務(wù)。它在其他6層工作的基礎(chǔ)上,負(fù)責(zé)完成網(wǎng)絡(luò)中應(yīng)用程序與網(wǎng)絡(luò)操作系統(tǒng)之間的聯(lián)系,建立與結(jié)束使用者之間的聯(lián)系,并完成網(wǎng)絡(luò)用戶提出的各種網(wǎng)絡(luò)服務(wù)及應(yīng)用所需的監(jiān)督、管理和服務(wù)等各種協(xié)議。此外,該層還負(fù)責(zé)協(xié)調(diào)各個(gè)應(yīng)用程序間的工作。應(yīng)用層為用戶提供的服務(wù)和協(xié)議有:文件服務(wù)、目錄服務(wù)、文件傳輸服務(wù)(FTP)、遠(yuǎn)程登錄服務(wù)(Telnet)、電子郵件服務(wù)(E-mail)、打印服務(wù)、安全服務(wù)、網(wǎng)絡(luò)管理服務(wù)、數(shù)據(jù)庫(kù)服務(wù)等。
好的上面我們淺述了OSI七層網(wǎng)絡(luò)模型,下面總結(jié)下:
OSI是一個(gè)理想的模型,一般的網(wǎng)絡(luò)系統(tǒng)只涉及其中的幾層,在七層模型中,每一層都提供一個(gè)特殊的網(wǎng)絡(luò)功能,從網(wǎng)絡(luò)功能角度觀察:
- 下面4層(物理層、數(shù)據(jù)鏈路層、網(wǎng)絡(luò)層和傳輸層)主要提供數(shù)據(jù)傳輸和交換功能,即以節(jié)點(diǎn)到節(jié)點(diǎn)之間的通信為主
- 第4層作為上下兩部分的橋梁,是整個(gè)網(wǎng)絡(luò)體系結(jié)構(gòu)中最關(guān)鍵的部分;
- 上3層(會(huì)話層、表示層和應(yīng)用層)則以提供用戶與應(yīng)用程序之間的信息和數(shù)據(jù)處理功能為主。
簡(jiǎn)言之,下4層主要完成通信子網(wǎng)的功能,上3層主要完成資源子網(wǎng)的功能。
——以上內(nèi)容參考自:OSI七層模型詳解
TCP/IP是一組協(xié)議的代名詞,它還包括許多協(xié)議,組成了TCP/IP協(xié)議簇。TCP/IP協(xié)議簇分為四層,IP位于協(xié)議簇的第二層(對(duì)應(yīng)OSI的第三層),TCP位于協(xié)議簇的第三層(對(duì)應(yīng)OSI的第四層)。TCP/IP通訊協(xié)議采用了4層的層級(jí)結(jié)構(gòu),每一層都呼叫它的下一層所提供的網(wǎng)絡(luò)來(lái)完成自己的需求。這4層分別為:
- 應(yīng)用層:應(yīng)用程序間溝通的層,如簡(jiǎn)單電子郵件傳輸(SMTP)、文件傳輸協(xié)議(FTP)、網(wǎng)絡(luò)遠(yuǎn)程訪問(wèn)協(xié)議(Telnet)等。
- 傳輸層:在此層中,它提供了節(jié)點(diǎn)間的數(shù)據(jù)傳送服務(wù),如傳輸控制協(xié)議(TCP)、用戶數(shù)據(jù)報(bào)協(xié)議(UDP)等,TCP和UDP給數(shù)據(jù)包加入傳輸數(shù)據(jù)并把它傳輸?shù)较乱粚又校@一層負(fù)責(zé)傳送數(shù)據(jù),并且確定數(shù)據(jù)已被送達(dá)并接收。
- 網(wǎng)絡(luò)互連層:負(fù)責(zé)提供基本的數(shù)據(jù)封包傳送功能,讓每一塊數(shù)據(jù)包都能夠到達(dá)目的主機(jī)(但不檢查是否被正確接收),如網(wǎng)際協(xié)議(IP)。
- 主機(jī)到網(wǎng)絡(luò)層:對(duì)實(shí)際的網(wǎng)絡(luò)媒體的管理,定義如何使用實(shí)際網(wǎng)絡(luò)(如Ethernet、Serial Line等)來(lái)傳送數(shù)據(jù)。
好吧,前兩點(diǎn)侃侃而談,只是給大家普及下OSI七層模型和TCP/IP四層模型的概念,接下來(lái)要講的是和我們Socket開(kāi)發(fā)相關(guān)的一些概念名詞了!
1. 用于區(qū)分不同的應(yīng)用程序
2. 端口號(hào)的范圍為0-65535,其中0-1023未系統(tǒng)的保留端口,我們的程序盡可能別使用這些端口!
3. IP地址和端口號(hào)組成了我們的Socket,Socket是網(wǎng)絡(luò)運(yùn)行程序間雙向通信鏈路的終結(jié)點(diǎn),是TCP和UDP的基礎(chǔ)!
4. 常用協(xié)議使用的端口:HTTP:80,F(xiàn)TP:21,TELNET:23
TCP協(xié)議流程詳解:
首先TCP/IP是一個(gè)協(xié)議簇,里面包括很多協(xié)議的。UDP只是其中的一個(gè)。之所以命名為TCP/IP協(xié)議,因?yàn)門CP,IP協(xié)議是兩個(gè)很重要的協(xié)議,就用他兩命名了。
下面我們來(lái)講解TCP協(xié)議和UDP協(xié)議的區(qū)別:
TCP(Transmission Control Protocol,傳輸控制協(xié)議)是面向連接的協(xié)議,即在收發(fā)數(shù)據(jù)錢,都需要與對(duì)面建立可靠的鏈接,這也是面試經(jīng)常會(huì)問(wèn)到的TCP的三次握手以及TCP的四次揮手!三次握手:建立一個(gè)TCP連接時(shí),需要客戶端和服務(wù)端總共發(fā)送3個(gè)包以確認(rèn)連接的建立,在Socket編程中,這一過(guò)程由客戶端執(zhí)行connect來(lái)觸發(fā),具體流程圖如下:
- 第一次握手:Client將標(biāo)志位SYN置為1,隨機(jī)產(chǎn)生一個(gè)值seq=J,并將該數(shù)據(jù)包發(fā)送給Server,Client進(jìn)入SYN_SENT狀態(tài),等待Server確認(rèn)。
- 第二次握手:Server收到數(shù)據(jù)包后由標(biāo)志位SYN=1知道Client請(qǐng)求建立連接,Server將標(biāo)志位SYN和ACK都置為1,ack=J+1,隨機(jī)產(chǎn)生一個(gè)值seq=K,并將該數(shù)據(jù)包發(fā)送給Client以確認(rèn)連接請(qǐng)求,Server進(jìn)入SYN_RCVD狀態(tài)。
- 第三次握手:Client收到確認(rèn)后,檢查ack是否為J+1,ACK是否為1,如果正確則將標(biāo)志位ACK置為1,ack=K+1,并將該數(shù)據(jù)包發(fā)送給Server,Server檢查ack是否為K+1,ACK是否為1,如果正確則連接建立成功,Client和Server進(jìn)入ESTABLISHED狀態(tài),完成三次握手,隨后Client與Server之間可以開(kāi)始傳輸數(shù)據(jù)了。
四次揮手:終止TCP連接,就是指斷開(kāi)一個(gè)TCP連接時(shí),需要客戶端和服務(wù)端總共發(fā)送4個(gè)包以確認(rèn)連接的斷開(kāi)。在Socket編程中,這一過(guò)程由客戶端或服務(wù)端任一方執(zhí)行close來(lái)觸發(fā),具體流程圖如下:
- 第一次揮手:Client發(fā)送一個(gè)FIN,用來(lái)關(guān)閉Client到Server的數(shù)據(jù)傳送,Client進(jìn)入FIN_WAIT_1狀態(tài)
- 第二次揮手:Server收到FIN后,發(fā)送一個(gè)ACK給Client,確認(rèn)序號(hào)為收到序號(hào)+1(與SYN相同,一個(gè)FIN占用一個(gè)序號(hào)),Server進(jìn)入CLOSE_WAIT狀態(tài)。
- 第三次揮手:Server發(fā)送一個(gè)FIN,用來(lái)關(guān)閉Server到Client的數(shù)據(jù)傳送,Server進(jìn)入LAST_ACK狀態(tài)。
- 第四次揮手:Client收到FIN后,Client進(jìn)入TIME_WAIT狀態(tài),接著發(fā)送一個(gè)ACK給Server,確認(rèn)序號(hào)為收到序號(hào)+1,Server進(jìn)入CLOSED狀態(tài),完成四次揮手。另外也可能是同事發(fā)起主動(dòng)關(guān)閉的情況:
另外還可能有一個(gè)常見(jiàn)的問(wèn)題就是:為什么建立連接是三次握手,而關(guān)閉連接卻是四次揮手呢?答:因?yàn)榉?wù)端在LISTEN狀態(tài)下,收到建立連接請(qǐng)求的SYN報(bào)文后,把ACK和SYN放在一個(gè)報(bào)文里發(fā)送給客戶端。而關(guān)閉連接時(shí),當(dāng)收到對(duì)方的FIN報(bào)文時(shí),僅僅表示對(duì)方不再發(fā)送數(shù)據(jù)了但是還能接收數(shù)據(jù),己方也未必全部數(shù)據(jù)都發(fā)送給對(duì)方了,所以己方可以立即close,也可以發(fā)送一些數(shù)據(jù)給對(duì)方后,再發(fā)送FIN報(bào)文給對(duì)方來(lái)表示同意現(xiàn)在關(guān)閉連接,因此,己方ACK和FIN一般都會(huì)分開(kāi)發(fā)送。
UDP協(xié)議詳解:
UDP(User Datagram Protocol)用戶數(shù)據(jù)報(bào)協(xié)議,非連接的協(xié)議,傳輸數(shù)據(jù)之前源端和終端不建立連接,當(dāng)它想傳送時(shí)就簡(jiǎn)單地去抓取來(lái)自應(yīng)用程序的數(shù)據(jù),并盡可能快地把它扔到網(wǎng)絡(luò)上。在發(fā)送端,UDP傳送數(shù)據(jù)的速度僅僅是受應(yīng)用程序生成數(shù)據(jù)的速度、計(jì)算機(jī)的能力和傳輸帶寬的限制;在接收端,UDP把每個(gè)消息段放在隊(duì)列中,應(yīng)用程序每次從隊(duì)列中讀一個(gè)消息段。相比TCP就是無(wú)需建立鏈接,結(jié)構(gòu)簡(jiǎn)單,無(wú)法保證正確性,容易丟包
——上述內(nèi)容部分摘自:
針對(duì)不同的網(wǎng)絡(luò)通信層次,Java給我們提供的網(wǎng)絡(luò)功能有四大類:
本節(jié)我們只介紹前兩個(gè)類,Socket與Datagram到TCP和UDP的章節(jié)再講解!
~InetAddress的使用例子:
示例代碼:
public class InetAddressTest { public static void main(String[] args) throws Exception{ //獲取本機(jī)InetAddress的實(shí)例: InetAddress address = InetAddress.getLocalHost(); System.out.println("本機(jī)名:" + address.getHostName()); System.out.println("IP地址:" + address.getHostAddress()); byte[] bytes = address.getAddress(); System.out.println("字節(jié)數(shù)組形式的IP地址:" + Arrays.toString(bytes)); System.out.println("直接輸出InetAddress對(duì)象:" + address); }}運(yùn)行結(jié)果圖:
~URL:這個(gè)就不用說(shuō)了吧,忘了可以看會(huì)前面Http協(xié)議講解那里~
本節(jié)全是概念,看起來(lái)可能夠嗆的是把,不過(guò)看不懂也沒(méi)關(guān)系,知道七層模型每層叫什么,大概拿來(lái)干嘛,還有TCP三次握手和四次揮手,就可以了!當(dāng)然,這只是為了應(yīng)付面試~實(shí)際開(kāi)發(fā)我們哪會(huì)糾結(jié)這個(gè)...直接Socket是吧~嗯,下節(jié)我們就來(lái)開(kāi)始學(xué)習(xí)Android中的Socket通信~謝謝~
聯(lián)系客服