Java Socket編程(3)-1
發(fā)表時(shí)間:2023-08-15 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]服務(wù)器Sockets服務(wù)器并不是主動地建立連接.相反地,他們是被動地監(jiān)聽一個(gè)客戶端的連接請示然后給他們服務(wù).服務(wù)器是由類ServerSocket來建立的.下面的程序建立了一個(gè)服務(wù)器端socket并把...
服務(wù)器Sockets
服務(wù)器并不是主動地建立連接.相反地,他們是被動地監(jiān)聽一個(gè)客戶端的連接請示然后給他們服務(wù).服務(wù)器是由類ServerSocket來建立的.下面的程序建立了一個(gè)服務(wù)器端socket并把它綁定到80端口:
ServerSocket serverSocket = new ServerSocket(80, 5);
第一個(gè)參數(shù)是服務(wù)器要監(jiān)聽的端口.第二個(gè)參數(shù)是可選的.API文檔中說明了這是一個(gè)監(jiān)聽時(shí)間,但是在傳統(tǒng)的socket程序中第二個(gè)參數(shù)是監(jiān)聽深度.一個(gè)服務(wù)器可以同時(shí)接收多個(gè)連接請求,但是每次只能處理一個(gè).監(jiān)聽堆是一個(gè)無回答的連接請求隊(duì)列.上面的請求建立一個(gè)連接來處理最后五個(gè)請求.如果省略了后面的一個(gè)參數(shù),則默認(rèn)值是50.
ServerSocket serverSocket = new ServerSocket(80, 5);
一旦socket建立了并開始監(jiān)聽連接,進(jìn)來的連接將會建立并放在監(jiān)聽堆.accetp()方法把在堆中的連接取出來.
Socket clientSocket = serverSocket.accept();
這個(gè)方法返回一個(gè)用來與來訪者對話的客戶端連接.服務(wù)器本身不可能建立對話,相反地,服務(wù)器socket會使用accept()方法來產(chǎn)生一個(gè)新的socket.服務(wù)器socket依舊打開并排列新的連接請求.
與客戶端socket一樣,下面的一步建立輸入和輸出流:
DataInputStream inbound = new DataInputStream( clientSocket.getInputStream() ); DataOutputStream outbound = new DataOutputStream( clientSocket.getOutputStream() );
一般的I/O操作可以在新建的流中運(yùn)用.在服務(wù)器回應(yīng)前它等待客戶端發(fā)送一個(gè)空白的行.當(dāng)會話結(jié)束時(shí),服務(wù)器關(guān)閉流和客戶端socket.如果在隊(duì)列中沒有請示將會出現(xiàn)什么情況呢?那個(gè)方法將會等待一個(gè)的到來.這個(gè)行為叫阻塞.accept()方法將會阻塞服務(wù)器線程直到一個(gè)呼叫到來.當(dāng)5個(gè)連接處理完閉之后,服務(wù)器退出.任何的在隊(duì)列中的呼叫將會被取消.
所有的服務(wù)器都要有以下的基本的步驟:
1.建立一個(gè)服務(wù)器socket并開始監(jiān)聽.
2.使用accept()方法取得新的連接.
3.建立輸入和輸出流.
4.在已有的協(xié)議上產(chǎn)生會話.
5.關(guān)閉客戶端流和socket.
6.回到第二步或者到第七步.
7.關(guān)閉服務(wù)器socket.