Socket慨念指的是什么,針對這個(gè)問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。
目前成都創(chuàng)新互聯(lián)已為1000多家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)站空間、網(wǎng)站托管、服務(wù)器租用、企業(yè)網(wǎng)站設(shè)計(jì)、曲周網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。Java開發(fā)網(wǎng)絡(luò)軟件非常方便和強(qiáng)大,Java的這種力量來源于他獨(dú)有的一套強(qiáng)大的用于網(wǎng)絡(luò)的 api,這些API是一系列的類和接口,均位于包java.NET和javax.net中。在這篇文章中我們將介紹套接字(Socket)慨念,同時(shí)以實(shí)例說明如何使用Network API操縱套接字,在完成本文后,你就可以編寫網(wǎng)絡(luò)低端通訊軟件。
什么是套接字(Socket)?
Network API是典型的用于基于TCP/IP網(wǎng)絡(luò)Java程序與其他程序通訊,Network API依靠Socket進(jìn)行通訊。Socket可以看成在兩個(gè)程序進(jìn)行通訊連接中的一個(gè)端點(diǎn),一個(gè)程序?qū)⒁欢涡畔懭隨ocket中,該Socket將這段信息發(fā)送給另外一個(gè)Socket中,使這段信息能傳送到其他程序中。如圖1XML:namespace prefix = o ns = "urn:schemas-microsoft-com:Office:office" />
我們來分析一下圖1,Host A上的程序A將一段信息寫入Socket中,Socket的內(nèi)容被Host A的網(wǎng)絡(luò)管理軟件訪問,并將這段信息通過Host A的網(wǎng)絡(luò)接口卡發(fā)送到Host B,Host B的網(wǎng)絡(luò)接口卡接收到這段信息后,傳送給Host B的網(wǎng)絡(luò)管理軟件,網(wǎng)絡(luò)管理軟件將這段信息保存在Host B的Socket中,然后程序B才能在Socket中閱讀這段信息。
假設(shè)在圖1的網(wǎng)絡(luò)中添加第三個(gè)主機(jī)Host C,那么Host A怎么知道信息被正確傳送到Host B而不是被傳送到Host C中了呢?基于TCP/IP網(wǎng)絡(luò)中的每一個(gè)主機(jī)均被賦予了一個(gè)唯一的IP地址,IP地址是一個(gè)32位的無符號整數(shù),由于沒有轉(zhuǎn)變成二進(jìn)制,因此通常以小數(shù)點(diǎn)分隔,如:198.163.227.6,正如所見IP地址均由四個(gè)部分組成,每個(gè)部分的范圍都是0-255,以表示8位地址。
值得注意的是IP地址都是32位地址,這是IP協(xié)議版本4(簡稱ipv4)規(guī)定的,目前由于IPv4地址已近耗盡,所以ipv6地址正逐漸代替Ipv4地址,Ipv6地址則是128位無符號整數(shù)。
假設(shè)第二個(gè)程序被加入圖1的網(wǎng)絡(luò)的Host B中,那么由Host A傳來的信息如何能被正確的傳給程序B而不是傳給新加入的程序呢?這是因?yàn)槊恳粋€(gè)基于TCP/IP網(wǎng)絡(luò)通訊的程序都被賦予了唯一的端口和端口號,端口是一個(gè)信息緩沖區(qū),用于保留Socket中的輸入/輸出信息,端口號是一個(gè)16位無符號整數(shù),范圍是0-65535,以區(qū)別主機(jī)上的每一個(gè)程序(端口號就像房屋中的房間號),低于256的短口號保留給標(biāo)準(zhǔn)應(yīng)用程序,比如pop3的端口號就是110,每一個(gè)套接字都組合進(jìn)了IP地址、端口、端口號,這樣形成的整體就可以區(qū)別每一個(gè)套接字t,下面我們就來談?wù)剝煞N套接字:流套接字和自尋址數(shù)據(jù)套接字。
流套接字(Stream Socket)
無論何時(shí),在兩個(gè)網(wǎng)絡(luò)應(yīng)用程序之間發(fā)送和接收信息時(shí)都需要建立一個(gè)可靠的連接,流套接字依靠TCP協(xié)議來保證信息正確到達(dá)目的地,實(shí)際上,IP包有可能在網(wǎng)絡(luò)中丟失或者在傳送過程中發(fā)生錯(cuò)誤,任何一種情況發(fā)生,作為接受方的 TCP將聯(lián)系發(fā)送方TCP重新發(fā)送這個(gè)IP包。這就是所謂的在兩個(gè)流套接字之間建立可靠的連接。
流套接字在C/S程序中扮演一個(gè)必需的角色,客戶機(jī)程序(需要訪問某些服務(wù)的網(wǎng)絡(luò)應(yīng)用程序)創(chuàng)建一個(gè)扮演服務(wù)器程序的主機(jī)的IP地址和服務(wù)器程序(為客戶端應(yīng)用程序提供服務(wù)的網(wǎng)絡(luò)應(yīng)用程序)的端口號的流套接字對象。
客戶端流套接字的初始化代碼將IP地址和端口號傳遞給客戶端主機(jī)的網(wǎng)絡(luò)管理軟件,管理軟件將IP地址和端口號通過NIC傳遞給服務(wù)器端主機(jī);服務(wù)器端主機(jī)讀到經(jīng)過NIC傳遞來的數(shù)據(jù),然后查看服務(wù)器程序是否處于監(jiān)聽狀態(tài),這種監(jiān)聽依然是通過套接字和端口來進(jìn)行的;如果服務(wù)器程序處于監(jiān)聽狀態(tài),那么服務(wù)器端網(wǎng)絡(luò)管理軟件就向客戶機(jī)網(wǎng)絡(luò)管理軟件發(fā)出一個(gè)積極的響應(yīng)信號,接收到響應(yīng)信號后,客戶端流套接字初始化代碼就給客戶程序建立一個(gè)端口號,并將這個(gè)端口號傳遞給服務(wù)器程序的套接字(服務(wù)器程序?qū)⑹褂眠@個(gè)端口號識別傳來的信息是否是屬于客戶程序)同時(shí)完成流套接字的初始化。
如果服務(wù)器程序沒有處于監(jiān)聽狀態(tài),那么服務(wù)器端網(wǎng)絡(luò)管理軟件將給客戶端傳遞一個(gè)消極信號,收到這個(gè)消極信號后,客戶程序的流套接字初始化代碼將拋出一個(gè)異常對象并且不建立通訊連接,也不創(chuàng)建流套接字對象。這種情形就像打電話一樣,當(dāng)有人的時(shí)候通訊建立,否則電話將被掛起。
這部分的工作包括了相關(guān)聯(lián)的三個(gè)類:InetAddress, Socket, 和 ServerSocket。 .netAddress對象描繪了32位或128位IP地址,Socket對象代表了客戶程序流套接字,ServerSocket代表了服務(wù)程序流套接字,所有這三個(gè)類均位于包java.net中
關(guān)于Socket慨念指的是什么問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道了解更多相關(guān)知識。