tcp協議是乙個基本的網路協議,基本上所有的網路服務都是基於tcp協議的,如http,ftp
等等,所以要了解網路程式設計就必須了解基於tcp協議的程式設計。然而tcp協議是乙個龐雜的體系,要
徹底的弄清楚它的實現不是一天兩天的功夫,所幸的是在.net framework環境下,我們不必要去
部分——主機名和埠,如www.yesky.com:80中,www.yesky.com就是主機名,80指主機的80端
口,當然,主機名也可以用ip位址代替。當連線建立之後,就可以使用這個連線去傳送和接收數
據包,tcp協議的作用就是保證這些資料報能到達終點並且能按照正確的順序組裝起來。
是tcpclient和tcplistener。由其英文意義顯而易見,tcpclient類是基於tcp協議的客戶端類,
而tcplistener是伺服器端,監聽(listen)客戶端傳來的連線請求。tcpclient類通過tcp協議與
伺服器進行通訊並獲取資訊,它的內部封裝了乙個socket類的例項,這個socket物件被用來使用
tcp協議向伺服器請求和獲取資料。因為與遠端主機的互動是以資料流的形式出現的,所以傳輸
的資料可以使用.net framework中流處理技術讀寫。在我們下邊的例子中,你可以看到使用
networkstream類運算元據流的方法。
在下面的例子中,我們將建立乙個時間伺服器,包括伺服器端程式和客戶端程式。伺服器
端監聽客戶端的連線請求,建立連線以後向客戶端傳送當前的系統時間。
先執行伺服器端程式,下面截圖顯示了伺服器端程式執行的狀況:
然後執行客戶端程式,客戶端首先傳送連線請求到伺服器端,伺服器端回應後傳送當前時
間到客戶端,這是客戶端程式的截圖:
通過這個例子我們可以了解tcpclient類的基本用法,要使用這個類,必須使用
system.net.socket命名空間,本例用到的三個命名空間如下:
using system;
using system.net.sockets;
using system.text;//從位元組陣列中獲取字串時使用該命名空間中的類
首先討論一下客戶端程式,開始我們必須初始化乙個tcpclient類的例項:
tcpclient client = new tcpclient(hostname, portnum);
然後使用tcpclient類的getstream()方法獲取資料流,並且用它初始化乙個
networkstream類的例項:
networkstream ns = client.getstream();
注意,當使用主機名和埠號初始化tcpclient類的例項時,直到跟伺服器建立了連線,
這個例項才算真正建立,程式才能往下執行。如果因為網路不通,伺服器不存在,伺服器端口未
開放等等原因而不能連線,程式將丟擲異常並且中斷執行。
建立資料流之後,我們可以使用networkstream類的read()方法從流中讀取資料,使用
write()方法向流中寫入資料。讀取資料時,首先應該建立乙個緩衝區,具體的說,就是建立一
個byte型的陣列用來存放從流中讀取的資料。read()方法的原型描述如下:
public override int read(in byte buffer,int offset,int size)
buffer是緩衝陣列,offset是資料(位元組流)在緩衝陣列中存放的開始位置,size是讀取
的位元組數目,返回值是讀取的字
上海管道疏通節數。在本例中,簡單地使用該方法來讀取伺服器
反饋的資訊:
byte bytes = new byte[1024];//建立緩衝區
int bytesread = ns.read(bytes, 0, bytes.length);//讀取位元組流
然後顯示到螢幕上:
console.writeline(encoding.ascii.getstring(bytes,0,bytesread));
最後不要忘記關閉連線:
client.close();
下面是本例完整的程式清單:
using system;
using system.net.sockets;
using system.text;
namespace tcpclientexample
catch (exception e)
}
}
}
上面這個例子清晰地演示了
管道疏通客戶端程式的編寫要點,下面我們討論一下如何建立
伺服器程式。這個例子將使用tcplistener類,在13號埠監聽,一旦有客戶端連線,將立即向
客戶端傳送當前伺服器的時間資訊。
tcplistener的關鍵在於accepttcpclient()方法,該方法將檢測埠是否有未處理的連線
請求,如果有未處理
減速機的連線請求,該方法
減速器將使伺服器同客戶端建立連線,並且返回
乙個tcpclient物件,通過這個物件的
減速電機getstream方法建立同客戶端通訊的資料流。事實
上,tcplistener類還提供乙個更為靈活的方法
除濕機acceptsocket(),當然靈活的代價是複雜
,對於比較簡單的程式,accepttcpclient()已經足夠用了。此外,tcplistener類提供start()
方法開始監聽,提供stop()方法停止監聽。
首先我們使用埠初始化乙個tcplistener例項,並且開始在13埠監聽:
private const int portnum = 13;
tcplistener listener = new tcplistener(portnum);
listener.start();//開始監聽
如果有未處理的連線請求,使用accepttcpclient方法進行處理,並且獲取資料流:
tcpclient client = listener.accepttcpclient();
networkstream ns = client.getstream();
然後,獲取本機時間,並儲存在位元組陣列中,使用networkstream.write()方法寫入資料
流,然後客戶端就可以通過read()
傳奇世界私服方法從資料流中獲取這段資訊:
byte bytetime = encoding.ascii.getbytes(datetime.now.tostring());
ns.write(bytetime, 0, bytetime.length);
ns.close();//不要忘記關閉資料流和連線
client.close();
伺服器端程式完整的程式清單如下:
using system;
using system.net.sockets;
using system.text;
namespace timeserver
catch (exception e)
}
listener.stop();
}
}
}
樣?很簡單吧!
用C 實現基於TCP協議的網路通訊
在下面的例子中,我們將建立乙個時間伺服器,包括伺服器端程式和客戶端程式。伺服器端監聽客戶端的連線請求,建立連線以後向客戶端傳送當前的系統時間。先執行伺服器端程式,下面截圖顯示了伺服器端程式執行的狀況 然後執行客戶端程式,客戶端首先傳送連線請求到伺服器端,伺服器端回應後傳送當前時間到客戶端,這是客戶端...
用C 實現基於TCP協議的網路通訊
在下面的例子中,我們將建立乙個時間伺服器,包括伺服器端程式和客戶端程式。伺服器端監聽客戶端的連線請求,建立連線以後向客戶端傳送當前的系統時間。先執行伺服器端程式,下面截圖顯示了伺服器端程式執行的狀況 然後執行客戶端程式,客戶端首先傳送連線請求到伺服器端,伺服器端回應後傳送當前時間到客戶端,這是客戶端...
用C 實現基於TCP協議的網路通訊
例子中,你可以看到使用networkstream類運算元據流的方法。在下面的例子中,我們將建立乙個時間伺服器,包括伺服器端程式和客戶端程式。伺服器端監聽客戶端的連線請求,建立連線以後向客戶端傳送當前的系統時間。先執行伺服器端程式,下面截圖顯示了伺服器端程式執行的狀況 然後執行客戶端程式,客戶端首先傳...