關(guān)于tcp的握手與數(shù)據(jù)傳輸
對(duì)于tcp而言,2個(gè)問(wèn)題,第一個(gè)是握手和揮手,第二個(gè)是數(shù)據(jù)傳輸。 握手和揮手時(shí),并不傳輸真正的數(shù)據(jù)。只有在握手后,揮手前,才可進(jìn)行有效數(shù)據(jù)的傳輸。對(duì)于tcp的協(xié)議程序,首先要處理握手,因?yàn)椴贿M(jìn)行握手,是無(wú)法傳輸數(shù)據(jù)的,這當(dāng)然只是協(xié)議定義的,如果對(duì)于底層而言,就沒(méi)有這么復(fù)雜了,但對(duì)于網(wǎng)絡(luò)這樣龐雜的系統(tǒng)來(lái)說(shuō),建立一個(gè)有效穩(wěn)定的連接還是挺重要的。
本文引用地址:http://www.ex-cimer.com/article/201611/324061.htm那么程序首先,要對(duì)數(shù)據(jù)幀進(jìn)行拆解,核對(duì)去掉以太網(wǎng)幀,核對(duì)去掉ip幀,在ip幀中,判斷協(xié)議是否為tcp協(xié)議(即一幀開(kāi)始的第23位是否為06),當(dāng)?shù)弥猧p包內(nèi)封裝的是tcp協(xié)議后,我們就可以開(kāi)始判斷該tcp包是握手揮手包還是數(shù)據(jù)包了。對(duì)于下位機(jī)而言,如果不在程序上做處理,對(duì)于任何包,底層都可以接收。但我們必須要按照tcp協(xié)議規(guī)定的那樣來(lái)做,首先要判斷是否建立連接,如果沒(méi)有,則只接收握手包,而丟棄數(shù)據(jù)包和揮手包。
判斷握手包和揮手包在幀的第47個(gè)位,0x01(揮手),0x02(握手),0x10(應(yīng)答),0x11(揮手應(yīng)答),0x12(握手應(yīng)答),0x18(傳輸數(shù)據(jù)),只要判斷47位數(shù)據(jù)符合哪個(gè)即可做相應(yīng)處理。
握手過(guò)程為:
a:發(fā)送0x02給b,b:回復(fù)0x12給a,a:發(fā)送0x10給b
同時(shí)a在發(fā)送握手?jǐn)?shù)據(jù)時(shí)會(huì)帶一個(gè)序列號(hào),當(dāng)比收到序列號(hào)時(shí),加1后會(huì)回給a
握手后建立連接,建立連接后即可發(fā)送數(shù)據(jù)
發(fā)送數(shù)據(jù)時(shí),判斷幀的第47位是否為0x18,若是,則可將數(shù)據(jù)推入應(yīng)用層。
評(píng)論