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