當(dāng)前位置:首頁 > 物聯(lián)網(wǎng) > 網(wǎng)絡(luò)協(xié)議
[導(dǎo)讀]   Java最初是作為網(wǎng)絡(luò)編程語言出現(xiàn)的,其對(duì)網(wǎng)絡(luò)提供了高度的支持,使得客戶端和服務(wù)器的溝通變成了現(xiàn)實(shí),而在網(wǎng)絡(luò)編程中,使用最多的就是Socket。像大家熟悉的QQ、MSN都使用了Socket相

  Java最初是作為網(wǎng)絡(luò)編程語言出現(xiàn)的,其對(duì)網(wǎng)絡(luò)提供了高度的支持,使得客戶端和服務(wù)器的溝通變成了現(xiàn)實(shí),而在網(wǎng)絡(luò)編程中,使用最多的就是Socket。像大家熟悉的QQ、MSN都使用了Socket相關(guān)的技術(shù)。下面就讓我們一起揭開Socket的神秘面紗。

  Socket編程   一、網(wǎng)絡(luò)基礎(chǔ)知識(shí)(參考計(jì)算機(jī)網(wǎng)絡(luò))

  關(guān)于計(jì)算機(jī)網(wǎng)絡(luò)部分可以參考相關(guān)博客:

  《TCP/IP協(xié)議棧及OSI參考模型詳解》

  http://wangdy.blog.51cto.com/3845563/1588379

  1、兩臺(tái)計(jì)算機(jī)間進(jìn)行通訊需要以下三個(gè)條件:

  IP地址、協(xié)議、端口號(hào)

  2、TCP/IP協(xié)議:

  是目前世界上應(yīng)用最為廣泛的協(xié)議,是以TCP和IP為基礎(chǔ)的不同層次上多個(gè)協(xié)議的集合,也成TCP/IP協(xié)議族、或TCP/IP協(xié)議棧

  TCP:Transmission Control Protocol 傳輸控制協(xié)議

  IP:Internet Protocol 互聯(lián)網(wǎng)協(xié)議

  3、TCP/IP五層模型

  應(yīng)用層:HTTP、FTP、SMTP、Telnet等

  傳輸層:TCP/IP

  網(wǎng)絡(luò)層:

  數(shù)據(jù)鏈路層:

  物理層:網(wǎng)線、雙絞線、網(wǎng)卡等

  4、IP地址

  為實(shí)現(xiàn)網(wǎng)絡(luò)中不同計(jì)算機(jī)之間的通信,每臺(tái)計(jì)算機(jī)都必須有一個(gè)唯一的標(biāo)識(shí)---IP地址。

  32位二進(jìn)制

  5、端口

  區(qū)分一臺(tái)主機(jī)的多個(gè)不同應(yīng)用程序,端口號(hào)范圍為0-65535,其中0-1023位為系統(tǒng)保留。

  如:HTTP:80 FTP:21 Telnet:23

  IP地址+端口號(hào)組成了所謂的Socket,Socket是網(wǎng)絡(luò)上運(yùn)行的程序之間雙向通信鏈路的終結(jié)點(diǎn),是TCP和UDP的基礎(chǔ)

  6、Socket套接字:

  網(wǎng)絡(luò)上具有唯一標(biāo)識(shí)的IP地址和端口組合在一起才能構(gòu)成唯一能識(shí)別的標(biāo)識(shí)符套接字。

  Socket原理機(jī)制:

  通信的兩端都有Socket

  網(wǎng)絡(luò)通信其實(shí)就是Socket間的通信

  數(shù)據(jù)在兩個(gè)Socket間通過IO傳輸

  7、Java中的網(wǎng)絡(luò)支持

  針對(duì)網(wǎng)絡(luò)通信的不同層次,Java提供了不同的API,其提供的網(wǎng)絡(luò)功能有四大類:

  InetAddress:用于標(biāo)識(shí)網(wǎng)絡(luò)上的硬件資源,主要是IP地址

  URL:統(tǒng)一資源定位符,通過URL可以直接讀取或?qū)懭刖W(wǎng)絡(luò)上的數(shù)據(jù)

  Sockets:使用TCP協(xié)議實(shí)現(xiàn)的網(wǎng)絡(luò)通信Socket相關(guān)的類

  Datagram:使用UDP協(xié)議,將數(shù)據(jù)保存在用戶數(shù)據(jù)報(bào)中,通過網(wǎng)絡(luò)進(jìn)行通信。

  二、InetAddress

  InetAddress類用于標(biāo)識(shí)網(wǎng)絡(luò)上的硬件資源,標(biāo)識(shí)互聯(lián)網(wǎng)協(xié)議(IP)地址。

  該類沒有構(gòu)造方法

  

  三、URL類

  1、URL(Uniform Resource Locator)統(tǒng)一資源定位符,表示Internet上某一資源的地址,協(xié)議名:資源名稱

  

  2、使用URL讀取網(wǎng)頁內(nèi)容

  通過URL對(duì)象的openStream()方法可以得到指定資源的輸入流,通過流能夠讀取或訪問網(wǎng)頁上的資源

  

  四、TCP編程

  1、TCP協(xié)議是面向連接的、可靠的、有序的、以字節(jié)流的方式發(fā)送數(shù)據(jù),通過三次握手方式建立連接,形成傳輸數(shù)據(jù)的通道,在連接中進(jìn)行大量數(shù)據(jù)的傳輸,效率會(huì)稍低

  2、Java中基于TCP協(xié)議實(shí)現(xiàn)網(wǎng)絡(luò)通信的類

  客戶端的Socket類

  服務(wù)器端的ServerSocket類

  

  3、Socket通信的步驟

 ?、?創(chuàng)建ServerSocket和Socket

  ② 打開連接到Socket的輸入/輸出流

 ?、?按照協(xié)議對(duì)Socket進(jìn)行讀/寫操作

  ④ 關(guān)閉輸入輸出流、關(guān)閉Socket

  4、服務(wù)器端:

 ?、?創(chuàng)建ServerSocket對(duì)象,綁定監(jiān)聽端口

 ?、?通過accept()方法監(jiān)聽客戶端請(qǐng)求

 ?、?連接建立后,通過輸入流讀取客戶端發(fā)送的請(qǐng)求信息

 ?、?通過輸出流向客戶端發(fā)送鄉(xiāng)音信息

 ?、?關(guān)閉相關(guān)資源

  

  6、應(yīng)用多線程實(shí)現(xiàn)服務(wù)器與多客戶端之間的通信

 ?、?服務(wù)器端創(chuàng)建ServerSocket,循環(huán)調(diào)用accept()等待客戶端連接

 ?、?客戶端創(chuàng)建一個(gè)socket并請(qǐng)求和服務(wù)器端連接

 ?、?服務(wù)器端接受苦讀段請(qǐng)求,創(chuàng)建socket與該客戶建立專線連接

  ④ 建立連接的兩個(gè)socket在一個(gè)單獨(dú)的線程上對(duì)話

  ⑤ 服務(wù)器端繼續(xù)等待新的連接

  

  五、UDP編程

  UDP協(xié)議(用戶數(shù)據(jù)報(bào)協(xié)議)是無連接的、不可靠的、無序的,速度快

  進(jìn)行數(shù)據(jù)傳輸時(shí),首先將要傳輸?shù)臄?shù)據(jù)定義成數(shù)據(jù)報(bào)(Datagram),大小限制在64k,在數(shù)據(jù)報(bào)中指明數(shù)據(jù)索要達(dá)到的Socket(主機(jī)地址和端口號(hào)),然后再將數(shù)據(jù)報(bào)發(fā)送出去

  DatagramPacket類:表示數(shù)據(jù)報(bào)包

  DatagramSocket類:進(jìn)行端到端通信的類

  1、服務(wù)器端實(shí)現(xiàn)步驟

 ?、?創(chuàng)建DatagramSocket,指定端口號(hào)

  ② 創(chuàng)建DatagramPacket

 ?、?接受客戶端發(fā)送的數(shù)據(jù)信息

  ④ 讀取數(shù)據(jù)

  

  2、客戶端實(shí)現(xiàn)步驟

  ① 定義發(fā)送信息

 ?、?創(chuàng)建DatagramPacket,包含將要發(fā)送的信息

 ?、?創(chuàng)建DatagramSocket

 ?、?發(fā)送數(shù)據(jù)

  

  六、注意問題:

  1、多線程的優(yōu)先級(jí)問題:

  根據(jù)實(shí)際的經(jīng)驗(yàn),適當(dāng)?shù)慕档蛢?yōu)先級(jí),否側(cè)可能會(huì)有程序運(yùn)行效率低的情況

  2、是否關(guān)閉輸出流和輸入流:

  對(duì)于同一個(gè)socket,如果關(guān)閉了輸出流,則與該輸出流關(guān)聯(lián)的socket也會(huì)被關(guān)閉,所以一般不用關(guān)閉流,直接關(guān)閉socket即可

  3、使用TCP通信傳輸對(duì)象,IO中序列化部分

  4、socket編程傳遞文件,IO流部分

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉