JAVA語言項(xiàng)目11 JAVA網(wǎng)絡(luò)編程_第1頁
JAVA語言項(xiàng)目11 JAVA網(wǎng)絡(luò)編程_第2頁
JAVA語言項(xiàng)目11 JAVA網(wǎng)絡(luò)編程_第3頁
JAVA語言項(xiàng)目11 JAVA網(wǎng)絡(luò)編程_第4頁
JAVA語言項(xiàng)目11 JAVA網(wǎng)絡(luò)編程_第5頁
已閱讀5頁,還剩70頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、整理課件Java語言和計(jì)算機(jī)網(wǎng)絡(luò)緊密相連,語言和計(jì)算機(jī)網(wǎng)絡(luò)緊密相連,Java語言就是伴隨著互語言就是伴隨著互聯(lián)網(wǎng)的發(fā)展而不斷成熟的。聯(lián)網(wǎng)的發(fā)展而不斷成熟的。Java最出色的一個(gè)特點(diǎn)就是對(duì)網(wǎng)最出色的一個(gè)特點(diǎn)就是對(duì)網(wǎng)絡(luò)編程提供了強(qiáng)大的支持。絡(luò)編程提供了強(qiáng)大的支持。網(wǎng)絡(luò)上計(jì)算機(jī)之間的通信實(shí)質(zhì)上就是計(jì)算機(jī)上的應(yīng)用程序之網(wǎng)絡(luò)上計(jì)算機(jī)之間的通信實(shí)質(zhì)上就是計(jì)算機(jī)上的應(yīng)用程序之間進(jìn)行通信。網(wǎng)絡(luò)程序設(shè)計(jì)的目的就是直接或間接地通過網(wǎng)間進(jìn)行通信。網(wǎng)絡(luò)程序設(shè)計(jì)的目的就是直接或間接地通過網(wǎng)絡(luò)協(xié)議與其他計(jì)算機(jī)的相關(guān)程序進(jìn)行數(shù)據(jù)傳輸,從而實(shí)現(xiàn)網(wǎng)絡(luò)協(xié)議與其他計(jì)算機(jī)的相關(guān)程序進(jìn)行數(shù)據(jù)傳輸,從而實(shí)現(xiàn)網(wǎng)絡(luò)通信。網(wǎng)絡(luò)程序設(shè)計(jì)通常涉及

2、一個(gè)服務(wù)器和一個(gè)或多個(gè)客絡(luò)通信。網(wǎng)絡(luò)程序設(shè)計(jì)通常涉及一個(gè)服務(wù)器和一個(gè)或多個(gè)客戶機(jī)??蛻魴C(jī)向服務(wù)器發(fā)送請(qǐng)求,服務(wù)器響應(yīng)請(qǐng)求。因此,戶機(jī)。客戶機(jī)向服務(wù)器發(fā)送請(qǐng)求,服務(wù)器響應(yīng)請(qǐng)求。因此,本帝通過一個(gè)本帝通過一個(gè)Server - Client模型的網(wǎng)絡(luò)聊天程序的項(xiàng)日模型的網(wǎng)絡(luò)聊天程序的項(xiàng)日案例開發(fā),來了解案例開發(fā),來了解Java的網(wǎng)絡(luò)編程知識(shí)。的網(wǎng)絡(luò)編程知識(shí)。下一頁項(xiàng)目項(xiàng)目11 Java網(wǎng)絡(luò)編程網(wǎng)絡(luò)編程整理課件項(xiàng)目項(xiàng)目11 Java網(wǎng)絡(luò)編程網(wǎng)絡(luò)編程11.1 項(xiàng)目概述項(xiàng)目概述11.2 項(xiàng)目目的項(xiàng)目目的11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施11.5 項(xiàng)目總結(jié)項(xiàng)目總結(jié)11.6 擴(kuò)展演練

3、擴(kuò)展演練整理課件11.1 項(xiàng)目概述項(xiàng)目概述本項(xiàng)目說明如何利用本項(xiàng)目說明如何利用Socket開發(fā)一個(gè)開發(fā)一個(gè)Server-Client模型模型的網(wǎng)絡(luò)聊天程序??蛻舳讼蚍?wù)器發(fā)送請(qǐng)求,嘗試服務(wù)器建的網(wǎng)絡(luò)聊天程序??蛻舳讼蚍?wù)器發(fā)送請(qǐng)求,嘗試服務(wù)器建立連接,服務(wù)器可能接受或拒絕請(qǐng)求。一旦建立連接,客戶立連接,服務(wù)器可能接受或拒絕請(qǐng)求。一旦建立連接,客戶端和服務(wù)器就可以進(jìn)行通信。端和服務(wù)器就可以進(jìn)行通信。返回整理課件11.2 項(xiàng)目目的項(xiàng)目目的.了解網(wǎng)絡(luò)編程原理。了解網(wǎng)絡(luò)編程原理。.理解理解TCP/IP體系結(jié)構(gòu)。體系結(jié)構(gòu)。.掌握掌握InetAddress類、類、Socket類及類及ServerSocke

4、t類等類等的使用。的使用。.掌握基于掌握基于TCP協(xié)議的協(xié)議的Socket網(wǎng)絡(luò)編程。網(wǎng)絡(luò)編程。返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)項(xiàng)目開發(fā)背景知識(shí)項(xiàng)目開發(fā)背景知識(shí)1 網(wǎng)絡(luò)編程概述網(wǎng)絡(luò)編程概述網(wǎng)絡(luò)編程中有兩個(gè)主要的問題,一個(gè)是如何準(zhǔn)確地定位網(wǎng)絡(luò)網(wǎng)絡(luò)編程中有兩個(gè)主要的問題,一個(gè)是如何準(zhǔn)確地定位網(wǎng)絡(luò)上一臺(tái)或多臺(tái)主機(jī)及在主機(jī)上運(yùn)行的應(yīng)用程序,另一個(gè)就是上一臺(tái)或多臺(tái)主機(jī)及在主機(jī)上運(yùn)行的應(yīng)用程序,另一個(gè)就是找到主機(jī)及應(yīng)用程序后如何可靠高效地進(jìn)行數(shù)據(jù)傳輸。找到主機(jī)及應(yīng)用程序后如何可靠高效地進(jìn)行數(shù)據(jù)傳輸。1.網(wǎng)絡(luò)通信基礎(chǔ)網(wǎng)絡(luò)通信基礎(chǔ)下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)網(wǎng)絡(luò)通信是采用網(wǎng)

5、絡(luò)協(xié)議實(shí)現(xiàn)計(jì)算機(jī)之間的數(shù)據(jù)交換。所謂網(wǎng)絡(luò)通信是采用網(wǎng)絡(luò)協(xié)議實(shí)現(xiàn)計(jì)算機(jī)之間的數(shù)據(jù)交換。所謂網(wǎng)絡(luò)協(xié)議是指通信雙方約定好的規(guī)則集合,通常使用網(wǎng)絡(luò)協(xié)議是指通信雙方約定好的規(guī)則集合,通常使用TCP/IP協(xié)議。在協(xié)議。在TCP/IP體系結(jié)構(gòu)中網(wǎng)絡(luò)層主要負(fù)責(zé)網(wǎng)絡(luò)體系結(jié)構(gòu)中網(wǎng)絡(luò)層主要負(fù)責(zé)網(wǎng)絡(luò)主機(jī)的定位和數(shù)據(jù)傳輸?shù)穆酚?,由主機(jī)的定位和數(shù)據(jù)傳輸?shù)穆酚桑蒊P地址可以唯一地確定地址可以唯一地確定Internet上的一臺(tái)主機(jī)。而傳輸層則提供面向應(yīng)用的可靠上的一臺(tái)主機(jī)。而傳輸層則提供面向應(yīng)用的可靠的或非可靠的數(shù)據(jù)傳輸機(jī)制,來保證應(yīng)用程序的正常運(yùn)行。的或非可靠的數(shù)據(jù)傳輸機(jī)制,來保證應(yīng)用程序的正常運(yùn)行。先了解以下幾個(gè)概念。

6、先了解以下幾個(gè)概念。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)IP地址地址:即給每個(gè)連接在即給每個(gè)連接在Internet上的主機(jī)分配一個(gè)在全世上的主機(jī)分配一個(gè)在全世界范圍唯一的界范圍唯一的32bit地址。地址。IP地址的結(jié)構(gòu)使在地址的結(jié)構(gòu)使在Internet上上尋址很方便。尋址很方便。IP地址通常用更直觀的、以圓點(diǎn)分隔號(hào)的地址通常用更直觀的、以圓點(diǎn)分隔號(hào)的4個(gè)個(gè)十進(jìn)制數(shù)字表示,每一個(gè)數(shù)字對(duì)應(yīng)于十進(jìn)制數(shù)字表示,每一個(gè)數(shù)字對(duì)應(yīng)于8個(gè)二進(jìn)制的比特串。個(gè)二進(jìn)制的比特串。端口號(hào)端口號(hào)(Port Number):網(wǎng)絡(luò)通信時(shí)同一機(jī)器上的不同進(jìn)網(wǎng)絡(luò)通信時(shí)同一機(jī)器上的不同進(jìn)程的標(biāo)識(shí),其中程的標(biāo)

7、識(shí),其中11024為系統(tǒng)保留的端口號(hào)。每一項(xiàng)標(biāo)準(zhǔn)的為系統(tǒng)保留的端口號(hào)。每一項(xiàng)標(biāo)準(zhǔn)的Internet服務(wù)都有自己獨(dú)特的端口號(hào),該端口在所有的計(jì)服務(wù)都有自己獨(dú)特的端口號(hào),該端口在所有的計(jì)算機(jī)上均相同。例如,算機(jī)上均相同。例如,ftp具有默認(rèn)端口具有默認(rèn)端口21, http具有默認(rèn)具有默認(rèn)端口端口80。服務(wù)類型。服務(wù)類型(Service):網(wǎng)絡(luò)的各種服務(wù)。例如,超網(wǎng)絡(luò)的各種服務(wù)。例如,超文本傳輸協(xié)議文本傳輸協(xié)議(HTTP),文件傳輸協(xié)議,文件傳輸協(xié)議(FTP),遠(yuǎn)程登錄,遠(yuǎn)程登錄(Telnet),簡(jiǎn)單郵件傳輸協(xié)議,簡(jiǎn)單郵件傳輸協(xié)議(SMTP)。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐

8、知識(shí)套接字套接字(Socket):當(dāng)一臺(tái)主機(jī)上有多個(gè)進(jìn)程同時(shí)進(jìn)行通信,當(dāng)一臺(tái)主機(jī)上有多個(gè)進(jìn)程同時(shí)進(jìn)行通信,如何區(qū)別從網(wǎng)絡(luò)中傳遞來的數(shù)據(jù)是一個(gè)問題,解決的方法就如何區(qū)別從網(wǎng)絡(luò)中傳遞來的數(shù)據(jù)是一個(gè)問題,解決的方法就是在傳輸層提供向上服務(wù)的端口號(hào)。端口號(hào)其實(shí)標(biāo)識(shí)了運(yùn)行是在傳輸層提供向上服務(wù)的端口號(hào)。端口號(hào)其實(shí)標(biāo)識(shí)了運(yùn)行在某臺(tái)計(jì)算機(jī)上的某個(gè)進(jìn)程,所以一個(gè)在在某臺(tái)計(jì)算機(jī)上的某個(gè)進(jìn)程,所以一個(gè)在Internet上運(yùn)行上運(yùn)行的應(yīng)用程序可以用的應(yīng)用程序可以用IP地址和端口號(hào)進(jìn)行標(biāo)識(shí),這就是套接字地址和端口號(hào)進(jìn)行標(biāo)識(shí),這就是套接字(Socket)。傳輸層以實(shí)現(xiàn)計(jì)算機(jī)系統(tǒng)端到端的通信為日的,該層提供了傳輸層以實(shí)現(xiàn)

9、計(jì)算機(jī)系統(tǒng)端到端的通信為日的,該層提供了兩種實(shí)現(xiàn)端到端通信的方法,即面向連接方法和無連接方法。兩種實(shí)現(xiàn)端到端通信的方法,即面向連接方法和無連接方法。這兩種方法對(duì)應(yīng)著兩個(gè)主要協(xié)議,一個(gè)是這兩種方法對(duì)應(yīng)著兩個(gè)主要協(xié)議,一個(gè)是TCP ( Transfer Control Protocol)協(xié)議,另一個(gè)是協(xié)議,另一個(gè)是UDP ( User Datagram Protocol)協(xié)議。協(xié)議。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)TCP是一種面向連接的保證可靠傳輸?shù)膮f(xié)議。通過是一種面向連接的保證可靠傳輸?shù)膮f(xié)議。通過TCP協(xié)議協(xié)議實(shí)現(xiàn)的傳輸,得到的是一個(gè)順序的無差錯(cuò)的數(shù)據(jù)流。發(fā)送方實(shí)現(xiàn)的

10、傳輸,得到的是一個(gè)順序的無差錯(cuò)的數(shù)據(jù)流。發(fā)送方和接收方的成對(duì)的兩個(gè)和接收方的成對(duì)的兩個(gè)socket之間必須建立連接,以便在之間必須建立連接,以便在TCP協(xié)議的基礎(chǔ)上進(jìn)行通信,當(dāng)一個(gè)協(xié)議的基礎(chǔ)上進(jìn)行通信,當(dāng)一個(gè)socket(通常都是通常都是server socket)等待建立連接時(shí),另一個(gè)等待建立連接時(shí),另一個(gè)socket可以要可以要求進(jìn)行連接,一旦這兩個(gè)求進(jìn)行連接,一旦這兩個(gè)socket連接起來,它們就可以進(jìn)行連接起來,它們就可以進(jìn)行雙向數(shù)據(jù)傳輸,雙方都可以進(jìn)行發(fā)送或接收操作。雙向數(shù)據(jù)傳輸,雙方都可以進(jìn)行發(fā)送或接收操作。UDP是一種無連接的協(xié)議,每個(gè)數(shù)據(jù)報(bào)都是一個(gè)獨(dú)立的信息,是一種無連接的協(xié)議

11、,每個(gè)數(shù)據(jù)報(bào)都是一個(gè)獨(dú)立的信息,包括完整的源地址和目的地址,它通過網(wǎng)絡(luò)上任何可能的路包括完整的源地址和目的地址,它通過網(wǎng)絡(luò)上任何可能的路徑傳往目的地,因此能否到達(dá)目的地,到達(dá)目的地的時(shí)間以徑傳往目的地,因此能否到達(dá)目的地,到達(dá)目的地的時(shí)間以及內(nèi)容的正確性都是不能被保證的,即及內(nèi)容的正確性都是不能被保證的,即UDP協(xié)議是不可靠的。協(xié)議是不可靠的。上一頁 下一頁返回整理課件上一頁11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)使用使用UDP時(shí),每個(gè)數(shù)據(jù)報(bào)中都給出了完整的地址信息,因此時(shí),每個(gè)數(shù)據(jù)報(bào)中都給出了完整的地址信息,因此無需要建立發(fā)送方和接收方的連接。對(duì)于無需要建立發(fā)送方和接收方的連接。對(duì)于TCP協(xié)議,由

12、于它協(xié)議,由于它是一個(gè)面向連接的協(xié)議,在是一個(gè)面向連接的協(xié)議,在socket之間進(jìn)行數(shù)據(jù)傳輸之前必之間進(jìn)行數(shù)據(jù)傳輸之前必然要建立連接,所以在然要建立連接,所以在TCP中多了一個(gè)連接建立的時(shí)間。中多了一個(gè)連接建立的時(shí)間。使用使用UDP傳輸數(shù)據(jù)時(shí)是有大小限制的,每個(gè)被傳輸?shù)臄?shù)據(jù)報(bào)傳輸數(shù)據(jù)時(shí)是有大小限制的,每個(gè)被傳輸?shù)臄?shù)據(jù)報(bào)必須限定在必須限定在64 KB之內(nèi)。而之內(nèi)。而TCP沒有這方面的限制,一旦連沒有這方面的限制,一旦連接建立起來,雙方的接建立起來,雙方的socket就可以按統(tǒng)一的格式傳輸大量的就可以按統(tǒng)一的格式傳輸大量的數(shù)據(jù)。數(shù)據(jù)。UDP是一個(gè)不可靠的協(xié)議,發(fā)送方所發(fā)送的數(shù)據(jù)報(bào)并是一個(gè)不可靠的協(xié)

13、議,發(fā)送方所發(fā)送的數(shù)據(jù)報(bào)并不一定以相同的次序到達(dá)接收方。而不一定以相同的次序到達(dá)接收方。而TCP是一個(gè)可靠的協(xié)議,是一個(gè)可靠的協(xié)議,它確保接收方完全正確地獲取發(fā)送方所發(fā)送的全部數(shù)據(jù)。它確保接收方完全正確地獲取發(fā)送方所發(fā)送的全部數(shù)據(jù)。下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)總之,總之,TCP在網(wǎng)絡(luò)通信上有極強(qiáng)的生命力,例如遠(yuǎn)程連接在網(wǎng)絡(luò)通信上有極強(qiáng)的生命力,例如遠(yuǎn)程連接(Telnet)和文件傳輸和文件傳輸(FTP)都需要不定長(zhǎng)度的數(shù)據(jù)被可靠都需要不定長(zhǎng)度的數(shù)據(jù)被可靠地傳輸。相比之下,地傳輸。相比之下,UDP操作簡(jiǎn)單,僅需要較少的監(jiān)護(hù),因操作簡(jiǎn)單,僅需要較少的監(jiān)護(hù),因此通常用于局域網(wǎng)高

14、可靠性的分散系統(tǒng)此通常用于局域網(wǎng)高可靠性的分散系統(tǒng)client/server應(yīng)用應(yīng)用程序中。程序中。可靠的傳輸是要付出代價(jià)的,對(duì)數(shù)據(jù)內(nèi)容正確性的檢驗(yàn)必然可靠的傳輸是要付出代價(jià)的,對(duì)數(shù)據(jù)內(nèi)容正確性的檢驗(yàn)必然占用計(jì)算機(jī)的處理時(shí)間和網(wǎng)絡(luò)的帶寬,因此在多次少量的非占用計(jì)算機(jī)的處理時(shí)間和網(wǎng)絡(luò)的帶寬,因此在多次少量的非緊要數(shù)據(jù)的傳輸中緊要數(shù)據(jù)的傳輸中TCP傳輸?shù)男什蝗鐐鬏數(shù)男什蝗鏤DP高。在許多應(yīng)用高。在許多應(yīng)用中并不需要保證嚴(yán)格的傳輸可靠性,比如視頻會(huì)議系統(tǒng),并中并不需要保證嚴(yán)格的傳輸可靠性,比如視頻會(huì)議系統(tǒng),并不要求音頻視頻數(shù)據(jù)絕對(duì)的正確,只要保證連貫性就可以了,不要求音頻視頻數(shù)據(jù)絕對(duì)的正確,只要

15、保證連貫性就可以了,這種情況下顯然使用這種情況下顯然使用UDP會(huì)更合理。會(huì)更合理。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)類類Java中與網(wǎng)絡(luò)通信有關(guān)的類都存在于包中。中與網(wǎng)絡(luò)通信有關(guān)的類都存在于包中。InetAddress類用于獲得目標(biāo)主機(jī)的類用于獲得目標(biāo)主機(jī)的IP地址。該類提供了通過地址。該類提供了通過IP主機(jī)名獲主機(jī)名獲得得IP主機(jī)地址的方法,而主機(jī)名對(duì)于使用者遠(yuǎn)比主機(jī)地址的方法,而主機(jī)名對(duì)于使用者遠(yuǎn)比IP地址來得地址來得方便。該類中常用的方法如下。方便。該類中常用的方法如下。(1) GetHostName():返回該地址的主機(jī)名。如果主機(jī)名返回該地址的主機(jī)名。如果主

16、機(jī)名為為null ,那么,當(dāng)前地址指向當(dāng)?shù)貦C(jī)器的任一可得網(wǎng)絡(luò)地址,那么,當(dāng)前地址指向當(dāng)?shù)貦C(jī)器的任一可得網(wǎng)絡(luò)地址,返回值類型為返回值類型為string。(2) GetHostAddress():以以“%d%d%d%d”的形式的形式返回返回IP地址串。返回值類型為地址串。返回值類型為string。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)(3)GelByName (stringhost):返回指定主機(jī)的返回指定主機(jī)的IP地址。地址。如果主機(jī)名為如果主機(jī)名為null ,則返回當(dāng)?shù)貦C(jī)器的默認(rèn)地址。參數(shù)則返回當(dāng)?shù)貦C(jī)器的默認(rèn)地址。參數(shù)host表示指定的主機(jī),返回值類型為表示指定的主機(jī),返

17、回值類型為InetAddress。 (4)GetAllByName (string host):返回指定主機(jī)名的返回指定主機(jī)名的所有所有InetAddrcss對(duì)象。參數(shù)對(duì)象。參數(shù)host表示指定的主機(jī)。返回表示指定的主機(jī)。返回值存放于值存放于InetAddrcss數(shù)組中。數(shù)組中。(5)GetLocalHost():返回本地主機(jī)的返回本地主機(jī)的InetAddrcss對(duì)象。對(duì)象。由于由于InetAddrcss類沒有構(gòu)造方法,它的實(shí)例對(duì)象需要過類沒有構(gòu)造方法,它的實(shí)例對(duì)象需要過方法方法getByName()、getLocalHost()以及以及getAllByName()來建立。來建立。上一頁 下一

18、頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)【例例11-1】源程序名,獲取本機(jī)的源程序名,獲取本機(jī)的IP地址。地址。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)【運(yùn)行結(jié)果運(yùn)行結(jié)果】如圖如圖11-1所示。所示。【程序分析程序分析】第第6行通過創(chuàng)建行通過創(chuàng)建InetAddrcss類的類的GetLocalHost()方法方法來達(dá)到獲取主機(jī)來達(dá)到獲取主機(jī)IP的目的。的目的。項(xiàng)目開發(fā)背景知識(shí)項(xiàng)目開發(fā)背景知識(shí)2: Java與與Socket編編程程Socket編程是網(wǎng)絡(luò)編程的核心內(nèi)容。網(wǎng)絡(luò)上的兩個(gè)程序通編程是網(wǎng)絡(luò)編程的核心內(nèi)容。網(wǎng)絡(luò)上的兩個(gè)程序通過一個(gè)雙向的通信連接實(shí)現(xiàn)數(shù)據(jù)的交換,這個(gè)雙

19、向鏈路的一過一個(gè)雙向的通信連接實(shí)現(xiàn)數(shù)據(jù)的交換,這個(gè)雙向鏈路的一端稱為一個(gè)套接字端稱為一個(gè)套接字(Socket)。套接字通常用來實(shí)現(xiàn)客戶方。套接字通常用來實(shí)現(xiàn)客戶方和服務(wù)方的連接。和服務(wù)方的連接。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)Socket可理解是一種用于表達(dá)兩臺(tái)機(jī)器之間連接可理解是一種用于表達(dá)兩臺(tái)機(jī)器之間連接“終端終端”的軟件抽象。對(duì)于一個(gè)給定的連接,在每臺(tái)機(jī)器上都有一個(gè)的軟件抽象。對(duì)于一個(gè)給定的連接,在每臺(tái)機(jī)器上都有一個(gè)socket,可以想象一個(gè)虛擬的,可以想象一個(gè)虛擬的“電纜電纜”工作在兩臺(tái)機(jī)器之間,工作在兩臺(tái)機(jī)器之間,“電纜電纜”插在兩臺(tái)機(jī)器的插在兩臺(tái)機(jī)器的s

20、ocket上。當(dāng)然,物理硬件和兩臺(tái)上。當(dāng)然,物理硬件和兩臺(tái)機(jī)器之間的機(jī)器之間的“電纜電纜”這些連接裝置都是未知的,抽象的所有這些連接裝置都是未知的,抽象的所有目的就是為了讓我們不必了解更多的細(xì)節(jié)。目的就是為了讓我們不必了解更多的細(xì)節(jié)。簡(jiǎn)單地說,一臺(tái)計(jì)算機(jī)上的簡(jiǎn)單地說,一臺(tái)計(jì)算機(jī)上的socket同另一臺(tái)計(jì)算機(jī)通話創(chuàng)建同另一臺(tái)計(jì)算機(jī)通話創(chuàng)建一個(gè)通信信道,程序員可以用這個(gè)信道在兩臺(tái)機(jī)器之間發(fā)送一個(gè)通信信道,程序員可以用這個(gè)信道在兩臺(tái)機(jī)器之間發(fā)送數(shù)據(jù)。在數(shù)據(jù)。在Java環(huán)境下,套接字編程主要是指基于環(huán)境下,套接字編程主要是指基于TCP/IP協(xié)協(xié)議的網(wǎng)絡(luò)編程。一個(gè)套接字由一個(gè)議的網(wǎng)絡(luò)編程。一個(gè)套接字由一

21、個(gè)IP地址和一個(gè)端口號(hào)唯一地址和一個(gè)端口號(hào)唯一確定。確定。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)中面向連接的流式中面向連接的流式Socket的通信機(jī)制的通信機(jī)制無論一個(gè)無論一個(gè)Socket的通信功能多么齊全,程序多么復(fù)雜,其的通信功能多么齊全,程序多么復(fù)雜,其基本結(jié)構(gòu)都是一樣的,具體過程如圖基本結(jié)構(gòu)都是一樣的,具體過程如圖11-2所示。所示。server端端首先在某個(gè)端口創(chuàng)建一個(gè)監(jiān)聽首先在某個(gè)端口創(chuàng)建一個(gè)監(jiān)聽Client請(qǐng)求的監(jiān)聽服務(wù)并處于請(qǐng)求的監(jiān)聽服務(wù)并處于監(jiān)聽狀態(tài),當(dāng)監(jiān)聽狀態(tài),當(dāng)Client向向server端的這個(gè)端口提出連接請(qǐng)求端的這個(gè)端口提出連接請(qǐng)求時(shí),時(shí),ser

22、ver端和端和Client端就建立了一個(gè)連接和一條傳輸數(shù)端就建立了一個(gè)連接和一條傳輸數(shù)據(jù)的通道,通信結(jié)束時(shí),這個(gè)連接通道將被拆除。據(jù)的通道,通信結(jié)束時(shí),這個(gè)連接通道將被拆除。具體來說,所有的客戶端程序都必須遵守下面的基本的步驟。具體來說,所有的客戶端程序都必須遵守下面的基本的步驟。(1)建立客戶端建立客戶端socket連接。連接。(2)得到得到socket的讀和寫的流。的讀和寫的流。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)(3) 利用流。利用流。(4)關(guān)閉流。關(guān)閉流。(5)關(guān)閉關(guān)閉socket。所有的服務(wù)器都要有以下的基本的步驟。所有的服務(wù)器都要有以下的基本的步驟。(1)建

23、立一個(gè)服務(wù)器建立一個(gè)服務(wù)器socket并開始監(jiān)聽。并開始監(jiān)聽。(2)使用使用accept()方法取得新的連接。方法取得新的連接。(3)建立輸入和輸出流。建立輸入和輸出流。(4)在已有的協(xié)議上產(chǎn)生會(huì)話。在已有的協(xié)議上產(chǎn)生會(huì)話。(5)關(guān)閉客戶端流和關(guān)閉客戶端流和socket。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)(6)回到第回到第2步或者到第步或者到第7步。步。(7)關(guān)閉服務(wù)器關(guān)閉服務(wù)器socket。類和類和ServerSocket類類在表在表11-1中有兩個(gè)不同的對(duì)象中有兩個(gè)不同的對(duì)象:Socket對(duì)象和對(duì)象和ServerSocket對(duì)象。這兩個(gè)對(duì)象就是從中提供的兩個(gè)類對(duì)象

24、。這兩個(gè)對(duì)象就是從中提供的兩個(gè)類Socket和和ServerSocket派生出來的。類派生出來的。類Socket和類和類ServerSocket是兩個(gè)封裝得非常好的類,它們是用是兩個(gè)封裝得非常好的類,它們是用Java實(shí)現(xiàn)流式實(shí)現(xiàn)流式Socket通信的主要工具。創(chuàng)建一個(gè)通信的主要工具。創(chuàng)建一個(gè)Socket對(duì)象就對(duì)象就建立了一個(gè)建立了一個(gè)Client和和Server之間的連接,創(chuàng)建一個(gè)之間的連接,創(chuàng)建一個(gè)ServerSocket對(duì)象就創(chuàng)建了一個(gè)監(jiān)聽服務(wù)。下面具體介紹對(duì)象就創(chuàng)建了一個(gè)監(jiān)聽服務(wù)。下面具體介紹這兩個(gè)類。這兩個(gè)類。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)構(gòu)造函數(shù)中的構(gòu)造

25、函數(shù)中的port是用來連接的端口號(hào)。是用來連接的端口號(hào)。maxqueue是隊(duì)是隊(duì)列長(zhǎng)度,該參數(shù)告訴系統(tǒng)多少與之連接的客戶在系統(tǒng)拒絕連列長(zhǎng)度,該參數(shù)告訴系統(tǒng)多少與之連接的客戶在系統(tǒng)拒絕連接之前可以掛起,默認(rèn)值是接之前可以掛起,默認(rèn)值是50。在一個(gè)多地址主機(jī)上,。在一個(gè)多地址主機(jī)上,localAddr用來指定該套接字約束的用來指定該套接字約束的IP地址。地址。(1)Socket類。類。在在Java中,一個(gè)中,一個(gè)Socket就代表了一個(gè)就代表了一個(gè)TCP連接,當(dāng)客戶端連接,當(dāng)客戶端要與服務(wù)器端連接時(shí),首先要?jiǎng)?chuàng)建一個(gè)要與服務(wù)器端連接時(shí),首先要?jiǎng)?chuàng)建一個(gè)Socket對(duì)象,服務(wù)對(duì)象,服務(wù)器端按照上文所述過

26、程產(chǎn)生另一個(gè)器端按照上文所述過程產(chǎn)生另一個(gè)Socket對(duì)象與其建立一對(duì)象與其建立一個(gè)基于流的通信信道。個(gè)基于流的通信信道。Socket對(duì)象創(chuàng)建后會(huì)自動(dòng)與指定的對(duì)象創(chuàng)建后會(huì)自動(dòng)與指定的主機(jī)和端口進(jìn)行連接,這一過程也有可能發(fā)生異常,系統(tǒng)會(huì)主機(jī)和端口進(jìn)行連接,這一過程也有可能發(fā)生異常,系統(tǒng)會(huì)拋出一個(gè)拋出一個(gè)IOException異常。異常。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)當(dāng)當(dāng)Client需要與需要與Server端連接,以獲取信息或服務(wù)時(shí),需端連接,以獲取信息或服務(wù)時(shí),需要?jiǎng)?chuàng)建一個(gè)要?jiǎng)?chuàng)建一個(gè)Socket對(duì)象,通常的寫法如下對(duì)象,通常的寫法如下:注意注意:引號(hào)中應(yīng)寫服務(wù)器主機(jī)

27、的名稱或地址,第二個(gè)參數(shù)是服引號(hào)中應(yīng)寫服務(wù)器主機(jī)的名稱或地址,第二個(gè)參數(shù)是服務(wù)器端進(jìn)行監(jiān)務(wù)器端進(jìn)行監(jiān)i聽服務(wù)的端口號(hào),端口號(hào)通常應(yīng)大于聽服務(wù)的端口號(hào),端口號(hào)通常應(yīng)大于1023,以防止與常用服務(wù)的端口沖突。以防止與常用服務(wù)的端口沖突。Socket對(duì)象創(chuàng)建后與服務(wù)器端進(jìn)行連接,如果成功就建立對(duì)象創(chuàng)建后與服務(wù)器端進(jìn)行連接,如果成功就建立了一個(gè)通信通道,就可以進(jìn)行數(shù)據(jù)通信。如果要進(jìn)行數(shù)據(jù)交了一個(gè)通信通道,就可以進(jìn)行數(shù)據(jù)通信。如果要進(jìn)行數(shù)據(jù)交換,還需要使用一些方法。換,還需要使用一些方法。Socket類提供了方法類提供了方法getInputStream和和getOutStream()來得到對(duì)應(yīng)的輸來得到

28、對(duì)應(yīng)的輸入入/輸出流以進(jìn)行讀輸出流以進(jìn)行讀/寫操作,這兩個(gè)方法分別返回寫操作,這兩個(gè)方法分別返回InputStream和和OutputSteam類對(duì)象。類對(duì)象。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)通信結(jié)束,可以調(diào)用通信結(jié)束,可以調(diào)用Socked對(duì)象的對(duì)象的close方法關(guān)閉,其寫方法關(guān)閉,其寫法如下法如下:cliSockct.close();(2)ServerSocket 類。類。當(dāng)創(chuàng)建一個(gè)當(dāng)創(chuàng)建一個(gè)ServerSocket類,它會(huì)在系統(tǒng)注冊(cè)自己對(duì)客戶類,它會(huì)在系統(tǒng)注冊(cè)自己對(duì)客戶連接感興趣連接感興趣ServerSocket類的構(gòu)造方法如下類的構(gòu)造方法如下:通??梢允褂米?/p>

29、簡(jiǎn)單的構(gòu)造方法產(chǎn)生一個(gè)通??梢允褂米詈?jiǎn)單的構(gòu)造方法產(chǎn)生一個(gè)ServerSocket對(duì)對(duì)象象:ServerSocket listener=newServerSocket(4000);上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)這里指定的監(jiān)聽服務(wù)端口是這里指定的監(jiān)聽服務(wù)端口是4000。用戶在一臺(tái)計(jì)算機(jī)上可。用戶在一臺(tái)計(jì)算機(jī)上可以同時(shí)建立多個(gè)以同時(shí)建立多個(gè)ServerSocket 對(duì)象,并分配不同的端口對(duì)象,并分配不同的端口號(hào),實(shí)現(xiàn)不同的服務(wù)。這樣,號(hào),實(shí)現(xiàn)不同的服務(wù)。這樣,Client連接到哪個(gè)端口,就可連接到哪個(gè)端口,就可以接受哪種服務(wù)。以接受哪種服務(wù)。ServerSocket對(duì)

30、象建立后還需要與對(duì)象建立后還需要與Client建立連接,這建立連接,這時(shí)需要執(zhí)行如下語行。時(shí)需要執(zhí)行如下語行。Socket linkSocket=listener.accept();accept是是ServerSocket類的一個(gè)方法,用來捕捉來自客類的一個(gè)方法,用來捕捉來自客戶端的連接請(qǐng)求,并建立一個(gè)與客戶端通信的戶端的連接請(qǐng)求,并建立一個(gè)與客戶端通信的Socket類對(duì)類對(duì)象象linkSocket,負(fù)責(zé)與客戶端連接。今后,負(fù)責(zé)與客戶端連接。今后,Server端程序端程序只需要向這個(gè)只需要向這個(gè)Socket對(duì)象讀寫數(shù)據(jù),就可以實(shí)現(xiàn)向遠(yuǎn)端的對(duì)象讀寫數(shù)據(jù),就可以實(shí)現(xiàn)向遠(yuǎn)端的Client讀寫數(shù)據(jù)。讀

31、寫數(shù)據(jù)。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)當(dāng)要結(jié)束監(jiān)聽時(shí),需要執(zhí)行如下語行關(guān)閉當(dāng)要結(jié)束監(jiān)聽時(shí),需要執(zhí)行如下語行關(guān)閉ServerSocket對(duì)對(duì)象,釋放其占用的資源即可。象,釋放其占用的資源即可。Listener. close();下面以服務(wù)器端為例,具體描述一下下面以服務(wù)器端為例,具體描述一下Socket類和類和ServerSocket類在服務(wù)器端程序編寫的步驟。類在服務(wù)器端程序編寫的步驟。(1)打開打開Socked,創(chuàng)建,創(chuàng)建ServerSocket對(duì)象。對(duì)象。ServerSocket s s=new ServerSocket(端口號(hào)端口號(hào));(2)等待客戶機(jī)的連接

32、。等待客戶機(jī)的連接。Socket sc=s.acccpt();上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)通過通過ServerSocket對(duì)象的對(duì)象的accept ()方法可以接收客戶機(jī)方法可以接收客戶機(jī)程序的連接請(qǐng)求,其返回值是一個(gè)程序的連接請(qǐng)求,其返回值是一個(gè)socket類型的對(duì)象。程序類型的對(duì)象。程序運(yùn)行到這里將處于等待狀態(tài)。運(yùn)行到這里將處于等待狀態(tài)。(3)生成輸入輸出流。生成輸入輸出流。通過通過ServerSocket對(duì)象的對(duì)象的GetOutputStream()和和GetInputsream()方法可以方法可以分別獲得輸出、輸入流。例如分別獲得輸出、輸入流。例如:上一

33、頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)輸入輸出流是網(wǎng)絡(luò)編程的實(shí)質(zhì)性部分,具體如何構(gòu)造所需要輸入輸出流是網(wǎng)絡(luò)編程的實(shí)質(zhì)性部分,具體如何構(gòu)造所需要的過濾流,要根據(jù)需要而定,能否運(yùn)用自如主要看讀者對(duì)的過濾流,要根據(jù)需要而定,能否運(yùn)用自如主要看讀者對(duì)Java中輸入輸出部分掌握如何。中輸入輸出部分掌握如何。(4)處理輸人輸出流。處理輸人輸出流。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)通過輸入流可以讀取客戶機(jī)程序發(fā)來的信息通過輸入流可以讀取客戶機(jī)程序發(fā)來的信息;通過輸出流可以通過輸出流可以向客戶機(jī)程序發(fā)信息。具體編程時(shí)所要考慮的是何時(shí)讀取信向客戶機(jī)程序發(fā)信息。具體編程

34、時(shí)所要考慮的是何時(shí)讀取信息以及何時(shí)發(fā)送信息。息以及何時(shí)發(fā)送信息。類類Socket提供了方法提供了方法getInputStream()和和getOutStream()來得到對(duì)應(yīng)的輸入來得到對(duì)應(yīng)的輸入/輸出流以進(jìn)行讀輸出流以進(jìn)行讀/寫寫操作,這兩個(gè)方法分別返回操作,這兩個(gè)方法分別返回InputStream和和OutputSteam類對(duì)象。為了便于讀類對(duì)象。為了便于讀/寫數(shù)據(jù),可以在返回寫數(shù)據(jù),可以在返回的輸入的輸入/輸出流對(duì)象上建立過濾流,如輸出流對(duì)象上建立過濾流,如DataInputStream, DataOutputStream或或PrintStream類對(duì)象,對(duì)于文本類對(duì)象,對(duì)于文本方式流對(duì)

35、象,可以采用方式流對(duì)象,可以采用InputStreamReader和和OutputStreamWriter, PrintWirter等處理。例如等處理。例如:上一頁 下一頁返回整理課件上一頁11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)(5)關(guān)閉關(guān)閉Socket下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)每一個(gè)每一個(gè)Socket存在時(shí),都將占用一定的資源,在存在時(shí),都將占用一定的資源,在Socket對(duì)對(duì)象使用完畢時(shí),要將其關(guān)閉。關(guān)閉象使用完畢時(shí),要將其關(guān)閉。關(guān)閉Socket可以調(diào)用可以調(diào)用Socket的的Close()方法。在關(guān)閉方法。在關(guān)閉Socket之前,應(yīng)將與之前,應(yīng)將與Socket相關(guān)相關(guān)

36、的所有的輸入的所有的輸入/輸出流全部關(guān)閉,以釋放所有的資源。而且輸出流全部關(guān)閉,以釋放所有的資源。而且要注意關(guān)閉的順序,與要注意關(guān)閉的順序,與Socket相關(guān)的所有的輸入相關(guān)的所有的輸入/輸出該首輸出該首先關(guān)閉,然后再關(guān)閉先關(guān)閉,然后再關(guān)閉Socket。上一頁 下一頁返回整理課件11.3 項(xiàng)目支撐知識(shí)項(xiàng)目支撐知識(shí)盡管盡管Java有自動(dòng)回收機(jī)制,網(wǎng)絡(luò)資源最終是會(huì)被釋放的。但有自動(dòng)回收機(jī)制,網(wǎng)絡(luò)資源最終是會(huì)被釋放的。但是為了有效地利用資源,建議讀者按照合理的順序主動(dòng)釋放是為了有效地利用資源,建議讀者按照合理的順序主動(dòng)釋放資源。資源。以上過程在采用線程編程時(shí),以上過程在采用線程編程時(shí),(1) (2)

37、可以放在主程序的循可以放在主程序的循環(huán)中,反復(fù)接收各個(gè)用戶的連接請(qǐng)求。接收到客戶機(jī)的連接環(huán)中,反復(fù)接收各個(gè)用戶的連接請(qǐng)求。接收到客戶機(jī)的連接請(qǐng)求后,請(qǐng)求后,(3) (4)可以交給線程處理。可以交給線程處理。上一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施這里要設(shè)計(jì)兩個(gè)程序。首先是服務(wù)器程序,然后是客戶端程這里要設(shè)計(jì)兩個(gè)程序。首先是服務(wù)器程序,然后是客戶端程序。序。服務(wù)器程序的實(shí)現(xiàn)服務(wù)器程序的實(shí)現(xiàn)服務(wù)器程序使用服務(wù)器程序使用Server Socket類監(jiān)聽指定端口,端口可類監(jiān)聽指定端口,端口可隨意指定隨意指定(由于由于1024以下的端口通常屬于保留端口,所以一以下的端口通常屬于保留端口,所以一般使用

38、大于般使用大于1024的端口的端口),等待客戶的連接請(qǐng)求。客戶連接,等待客戶的連接請(qǐng)求??蛻暨B接成功后,即服務(wù)器一客戶端套接字建立,在服務(wù)器和客戶端成功后,即服務(wù)器一客戶端套接字建立,在服務(wù)器和客戶端之間就形成了一條通道,這時(shí)站在服務(wù)器的角度看,客戶端之間就形成了一條通道,這時(shí)站在服務(wù)器的角度看,客戶端就相當(dāng)于一個(gè)輸入輸出設(shè)備,就可以使用就相當(dāng)于一個(gè)輸入輸出設(shè)備,就可以使用Socket類提供的類提供的兩個(gè)方法兩個(gè)方法getInputStream()和和getOunputStream()來對(duì)客戶端讀寫信息。來對(duì)客戶端讀寫信息。下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件

39、11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施【程序運(yùn)行分析程序運(yùn)行分析】 (1)首先運(yùn)行服務(wù)器程序,顯示界面如下首先運(yùn)行服務(wù)器程序,顯示界面如下圖圖11-3,當(dāng)單擊,當(dāng)單擊監(jiān)聽按鈕后,服務(wù)器開始掛起等待客戶的連接請(qǐng)求。監(jiān)聽按鈕后,服務(wù)器開始掛起等待客戶的

40、連接請(qǐng)求。上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施(2)一旦連接成功,服務(wù)器即可和客戶端之間發(fā)送和接收信一旦連接成功,服務(wù)器即可和客戶端之間發(fā)送和接收信息。運(yùn)行界面如圖息。運(yùn)行界面如圖11-4所示所示.客戶端程序的實(shí)現(xiàn)客戶端程序的實(shí)現(xiàn)客戶端程序使用客戶端程序使用Socked類向指定服務(wù)器及端口發(fā)出連接請(qǐng)類向指定服務(wù)器及端口發(fā)出連接請(qǐng)求,連接成功后,形成服務(wù)器一客戶端之間的套接字,即在求,連接成功后,形成服務(wù)器一客戶端之間的套接字,即在服務(wù)器一客戶端之間就形成了一條通道,這時(shí)站在客戶端的服務(wù)器一客戶端之間就形成了一條通道,這時(shí)站在客戶端的角度看,服務(wù)器相當(dāng)于一個(gè)輸入輸出設(shè)備,可以通過

41、角度看,服務(wù)器相當(dāng)于一個(gè)輸入輸出設(shè)備,可以通過Socket類提供的兩個(gè)方法類提供的兩個(gè)方法getInputStream()和和getOutputStream()來對(duì)服務(wù)器讀寫信息。來對(duì)服務(wù)器讀寫信息。上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4

42、項(xiàng)目實(shí)施項(xiàng)目實(shí)施上一頁 下一頁返回整理課件11.4 項(xiàng)目實(shí)施項(xiàng)目實(shí)施【程序運(yùn)行分析程序運(yùn)行分析】(1)客戶端程序初始運(yùn)行界面如圖客戶端程序初始運(yùn)行界面如圖11-5,當(dāng)單擊連接按鈕后,當(dāng)單擊連接按鈕后,客戶端向服務(wù)器的指定端口發(fā)出連接請(qǐng)求??蛻舳讼蚍?wù)器的指定端口發(fā)出連接請(qǐng)求。(2)一旦連接成功,客戶端即可和服務(wù)器之間發(fā)送和接收信一旦連接成功,客戶端即可和服務(wù)器之間發(fā)送和接收信息。運(yùn)行界面如圖息。運(yùn)行界面如圖11-6所示。所示。上一頁返回整理課件11.5 項(xiàng)目總結(jié)項(xiàng)目總結(jié)本帝的兩個(gè)案例展示廠網(wǎng)絡(luò)應(yīng)用中典型的本帝的兩個(gè)案例展示廠網(wǎng)絡(luò)應(yīng)用中典型的C/S結(jié)構(gòu),都是基結(jié)構(gòu),都是基于于TCP的應(yīng)用。通過以

43、上的學(xué)習(xí),應(yīng)該對(duì)的應(yīng)用。通過以上的學(xué)習(xí),應(yīng)該對(duì)Java的面向流的的面向流的網(wǎng)絡(luò)編程有了一個(gè)比較全面的認(rèn)識(shí)。下面介紹基于網(wǎng)絡(luò)編程有了一個(gè)比較全面的認(rèn)識(shí)。下面介紹基于UDP協(xié)議協(xié)議的網(wǎng)絡(luò)編程。的網(wǎng)絡(luò)編程。前面在介紹前面在介紹TCP/IP協(xié)議的時(shí)候,我們已經(jīng)提到,在協(xié)議的時(shí)候,我們已經(jīng)提到,在TCP/IP協(xié)議的傳輸層除廠協(xié)議的傳輸層除廠TCP協(xié)議之外還有一個(gè)協(xié)議之外還有一個(gè)UDP協(xié)議,協(xié)議,相比而言相比而言UDP的應(yīng)用不如的應(yīng)用不如TCP廣泛,幾個(gè)標(biāo)準(zhǔn)的應(yīng)用層協(xié)議廣泛,幾個(gè)標(biāo)準(zhǔn)的應(yīng)用層協(xié)議HTTP, FTP, SMTP二使用的都是二使用的都是TCP協(xié)議。但是,協(xié)議。但是,隨著計(jì)算機(jī)網(wǎng)絡(luò)的發(fā)展,隨著計(jì)

44、算機(jī)網(wǎng)絡(luò)的發(fā)展,UDP協(xié)議正越來越顯示出其威力,協(xié)議正越來越顯示出其威力,尤其是在需要很強(qiáng)的實(shí)時(shí)交互性的場(chǎng)合,如網(wǎng)絡(luò)游戲,視頻尤其是在需要很強(qiáng)的實(shí)時(shí)交互性的場(chǎng)合,如網(wǎng)絡(luò)游戲,視頻會(huì)議等,會(huì)議等,UDP更是顯示出極強(qiáng)的威力,下面我們就介紹一下更是顯示出極強(qiáng)的威力,下面我們就介紹一下Java環(huán)境下如何實(shí)現(xiàn)環(huán)境下如何實(shí)現(xiàn)UDP網(wǎng)絡(luò)傳輸。網(wǎng)絡(luò)傳輸。下一頁返回整理課件11.5 項(xiàng)目總結(jié)項(xiàng)目總結(jié)包中提供了兩個(gè)類包中提供了兩個(gè)類DatagramSocket和和DatagramPacket用來支持?jǐn)?shù)據(jù)報(bào)通信,用來支持?jǐn)?shù)據(jù)報(bào)通信, DatagramSocket用于在程序之間建立傳送數(shù)據(jù)報(bào)的通信用于在程序之間建立

45、傳送數(shù)據(jù)報(bào)的通信連接,連接, DatagramPacket則用來表示一個(gè)數(shù)據(jù)報(bào)。則用來表示一個(gè)數(shù)據(jù)報(bào)。1 .DatagramSocket類類構(gòu)造方法構(gòu)造方法:DatagramSocket();DatagramSocket(int prot);DatagramSocket(int port,InetAddress laddr)上一頁 下一頁返回整理課件11.5 項(xiàng)目總結(jié)項(xiàng)目總結(jié)其中,其中,port指明指明socket所使用的端口號(hào),如果未指明端口所使用的端口號(hào),如果未指明端口號(hào),則把號(hào),則把socket連接到本地主機(jī)上一個(gè)可用的端口。連接到本地主機(jī)上一個(gè)可用的端口。laddr指明一個(gè)可用的本地地

46、址。給出端口號(hào)時(shí)要保證不發(fā)生端口指明一個(gè)可用的本地地址。給出端口號(hào)時(shí)要保證不發(fā)生端口沖突,否則會(huì)生成沖突,否則會(huì)生成SocketException類例外。注意類例外。注意:上述的上述的兩個(gè)構(gòu)造方法都聲明拋棄非運(yùn)行時(shí)例兩個(gè)構(gòu)造方法都聲明拋棄非運(yùn)行時(shí)例SocketException,程序中必須進(jìn)行處理,或者捕獲、或者聲明拋棄。程序中必須進(jìn)行處理,或者捕獲、或者聲明拋棄。第一個(gè)構(gòu)造方法用來構(gòu)造一個(gè)用于發(fā)送數(shù)據(jù)報(bào)的第一個(gè)構(gòu)造方法用來構(gòu)造一個(gè)用于發(fā)送數(shù)據(jù)報(bào)的SocketException類,后兩種構(gòu)造方法用來構(gòu)造一個(gè)用于類,后兩種構(gòu)造方法用來構(gòu)造一個(gè)用于接收的接收的SocketException類。類。

47、上一頁 下一頁返回整理課件11.5 項(xiàng)目總結(jié)項(xiàng)目總結(jié)類類用數(shù)據(jù)報(bào)方式編寫用數(shù)據(jù)報(bào)方式編寫client/server程序時(shí),無論在客戶端還程序時(shí),無論在客戶端還是服務(wù)器端,首先都要建立一個(gè)是服務(wù)器端,首先都要建立一個(gè)DatagramPacket對(duì)象,對(duì)象,用來接收或發(fā)送數(shù)據(jù)報(bào),然后使用用來接收或發(fā)送數(shù)據(jù)報(bào),然后使用DatagramPacket類對(duì)類對(duì)象作為傳輸數(shù)據(jù)的載體。象作為傳輸數(shù)據(jù)的載體。構(gòu)造方法構(gòu)造方法:上一頁 下一頁返回整理課件11.5 項(xiàng)目總結(jié)項(xiàng)目總結(jié)其中,其中,buf中存放數(shù)據(jù)報(bào)數(shù)據(jù),中存放數(shù)據(jù)報(bào)數(shù)據(jù),length為數(shù)據(jù)報(bào)中數(shù)據(jù)的長(zhǎng)為數(shù)據(jù)報(bào)中數(shù)據(jù)的長(zhǎng)度,度,addr和和port指明日的地址,指明日的地址,offset指明了數(shù)據(jù)報(bào)的位指明了數(shù)據(jù)報(bào)的位移量。移量。在接收數(shù)據(jù)前,應(yīng)該采用上面的第一種方法生成一個(gè)在接收數(shù)據(jù)前,應(yīng)該采用上面的第一種方法生成一個(gè)Datagram

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論