主頁 > 資料庫 > Java高級程式設計筆記 • 【第4章 網路編程】

Java高級程式設計筆記 • 【第4章 網路編程】

2020-10-03 17:14:43 資料庫

全部章節 >>>>


本章目錄

4.1 網路基礎知識

4.1.1 IP地址

4.1.2 埠號

4.1.3 使用InetAddress

4.1.4 InetAddress 類的具體操作

4.1.5 實踐練習

4.2 基于TCP協議的網路編程

4.2.1 TCP 協議基礎

4.2.2 創建服務端套接字

4.2.3 創建客戶端套接字

4.2.4 基于TCP的通信

4.2.5 實踐練習

4.3 使用 Socket 類進行單向通信

4.3.1 服務端讀取資料

4.3.2 客戶端發送資料

4.3.3 實踐練習

4.4 使用Socket類進行雙向通信

4.4.1 雙向通信服務端

4.4.2 雙向通信客戶端

4.4.3 TCP雙向通信

4.4.4 實踐練習

總結:


4.1 網路基礎知識

  • 計算機網路,就是將分布在不同地域的計算機與專門的外部設備用通信線路互聯成一個規模龐大、功能強大的網路系統,從而使眾多計算機可以方便地互相傳遞資訊,共享資料資訊資源
  • 網路中不可避免的就是資訊互動,而多臺計算機終端之間的資訊互動就必須依靠網路編程實作,Java中也針對網路通信提供了大量的API,使開發網路通信應用變的更為簡單

4.1.1 IP地址

  • IP 地址用于唯一標識網路中的一臺計算機,也可以是一臺列印機或一部智能手機等終端設備,網路中每臺計算機都有獨立唯一IP地址
  • IP 地址是一個 32 位整數,通常將其分為 4 個 8 位的二進制資料,每位之間用圓點隔開,每個8 位整數可以轉換成一個 0 ~ 255 的十進制整數,如局域網IP通常為192.168.0.XXX

技巧:在windows作業系統的命令提示符下,輸入ipconfig可以查看本機ip地址

4.1.2 埠號

提問:

  • 通過IP地址可以定位到具體設備,電腦中有很多軟體,如何能把資訊資料發送給指定軟體接收
  • 埠是一個 16 位的整數,用于表示資料交給哪個計算機中的通信程式(微信、QQ 或 LOL 等)處理,不同的應用程式處理不同埠上的資料,同一臺計算機上不能有兩個程式使用同一個埠,埠號為 0 ~ 65535

提醒:

前1024個埠已被系統占用,使用時盡量避開常用埠

4.1.3 使用InetAddress

Java 提供了 InetAddress 類代表 IP 地址,InetAddress 下還有兩個子類 Inet4Address 和 Inet6Address,它們分別代表 IPv4 和 IPv6 地址 InetAddress 類沒有提供構造方法,而是提供了靜態方法來獲取 InetAddress 實體

方法名

作用

public static InetAddress getName(String host)

根據主機獲取對應的 InetAddress 物件

Public static InetAddress getLocalHost()

獲取本機 IP 地址所對應的 InetAddress 實體

public String getHostAddress()

回傳該 InetAddress 實體所對應的 IP 地址字串

public String getHostName()

回傳此 IP 地址的主機名稱

4.1.4 InetAddress 類的具體操作

示例:根據主機名獲取對應的 InetAddress 物件

// 根據主機名獲取對應的 InetAddress 物件
InetAddress ip = InetAddress.getByName("www.sina.com");
// 獲取該 InetAddress 實體的 IP 地址字串
String ipStr = ip.getHostAddress();
System.out.println(" 新浪網地址 :" + ipStr);
// 獲取該 InetAddress 實體的主機名稱
String hostName = ip.getHostName();
System.out.println(" 新浪主機名 :" + hostName);

4.1.5 實踐練習

4.2 基于TCP協議的網路編程

4.2.1 TCP 協議基礎

  • TCP/IP 通信協議是一種可靠的網路協議,它在通信的兩端各建立一個 Socket,從而在通信的兩端之間形成網路的虛擬鏈路,兩端的程式就可以通過虛擬鏈路進行通信
  • Java 對基于 TCP 協議的網路通信提供了良好的封裝,Java 使用 Socket 來代表連接的通信埠,并通過 Socket 產生的 I/O 流來進行網路通信
  • 使用 TCP 協議撰寫網路程式,需要提供服務端程式和客戶端程式
  • Java 中的 ServerSocket 類作用類似于114 查號臺總機,Socket 類可以實作普通電話和 114 查號臺的分機通話功能,整個互動程序如下圖

基于TCP協議服務端和客戶端建立連接步驟

  1. 服務端程式創建 ServerSocket 物件,呼叫 accept() 方法,等待客戶端連接
  2. 客戶端程式創建 Socket 物件并請求與服務端建立連接
  3. 服務端接收客戶端的連接請求,并創建新的 Socket 物件與客戶端建立專線連接
  4. 實作(2)和(3)步驟中建立連接的兩個 Socket 類在同一執行緒上對話
  5. 服務端重新等待新的連接請求

4.2.2 創建服務端套接字

在 Java 中使用的 ServerSocket 物件用戶監聽是來自客戶端的 Socket 類連接,如果沒有連接,它將一直處于等待狀態,ServerSocket 類包含一個來自客戶端的連接請求的監聽方法

ServerSocket 類的常用方法

方法名

作用

public ServerSocket(int port)

構造方法,用指定埠創建 ServerSocket 實體

public Socket accept()

接收客戶端的 Socket 類請求

public InetAddress getInetAddress()

回傳服務端主機 IP 地址

public void close()

關閉 ServerSocket 物件

serverSocket實體呼叫accept方法后,就處于等待狀態

示例:使用ServerSocket創建服務端

// 創建 ServerScoket 實體,并在 8888 埠監聽客戶端
ServerSocket server = new ServerSocket(8888);
// 呼叫 accep() 方法等待客戶端的連接,該方法是一個阻塞方法,如果沒有客戶端請求服務,該方法下的代碼將不會執行
System.out.println(" 服務端套接字已經創建,開始等待來自客戶端的連接 ");
Socket socket = server.accept();
System.out.println(" 有客戶端已成功連接 ");

4.2.3 創建客戶端套接字

客戶端使用 Socket 類連接到指定的服務端,每個 Socket 物件代表一個客戶端,Socket 類的常用方法如下表

方法名

作用

public Socket(String host,int port)

public Socket(String host,int port) 構造方法,創建連接到指定遠程主機和埠的 Socket 實體

public InputStream getInputStream()

回傳該 Socket 物件對應的輸入流

public OutputStream getOutputStream()

回傳該 Socket 物件對應的輸出流

public void close()

關閉 ServerSocket 物件

int port Ip和埠必須和服務端保持一致

示例:使用Socket創建客戶端和服務端連接

// 創建客戶端 Socket 實體,連接指定 IP 地址和指定埠的服務端
Socket socket = new Socket("127.0.0.1", 8888);

說明:

  • 示例中的127.0.0.1代表本機,也可以使用本地IP地址,如果連接網路中其他電腦,則更改為對應IP即可
  • 代碼執行程序中注意進行合理的例外處理,網路編程中可能出現的例外較多

4.2.4 基于TCP的通信

提問:

剛才實作的僅僅為兩臺設備通過TCP方式建立連接,如何進行通信?

在建立連接的基礎之上,可以通過前面學習的輸入流、輸出流進行資訊的發送和接收,從Socket中可以獲取輸入流、輸出流

示例:使用輸入輸出流進行資訊發送和接收

客戶端程式發送資料

// 創建 ServerSocket 類,用于監聽客戶端 Socket 類的請求連接
ServerSocket server = new ServerSocket(8888);
// 等待客戶端的連接,客戶端連接后,與客戶端對應一個 Socket 管道
Socket socket = server.accept();
// 獲得 Socket 管道輸入的資料的位元組輸入流
OutputStream out = socket.getOutputStream();
// 使用列印流包裝位元組輸出流,更為方便輸出內容
PrintWriter writer = new PrintWriter(out);
writer.println(“ 歡迎您的訪問 ”);	//發送資訊
writer.close();
server.close();

客戶端程式讀取資料

// 客戶端連接到本機埠號是 8888 的服務端
Socket socket = new Socket("127.0.0.1", 8888);
// 獲得 Socket 管道中獲取讀取資料的位元組輸入流
InputStream in = (InputStream) socket.getInputStream();
// 為了便于讀取資料,將 in 轉換成字符流
InputStreamReader isr = new InputStreamReader(in);
// 用 BufferdReader 包裝轉換后的字符流
BufferedReader reader = new BufferedReader(isr);
String data = reader.readLine();
System.out.println(" 服務端對客戶端說 :" + data);
reader.close();
socket.close();

4.2.5 實踐練習

4.3 使用 Socket 類進行單向通信

使用 Socket 類套接字,可以進行服務端和客戶端的通信,Socket 類通信主要分為單向通信和多向通信兩種

單向通信就是指只有一端發送資料,另一端只需接收資料,比如,服務端發送資料到客戶端,客戶端不需要發送資料到服務端

4.3.1 服務端讀取資料

示例代碼:

// 創建服務端套接字,監聽 8888 介面
server = new ServerSocket(8888);
// 保存客戶端發送的資料
String data = null;
while (true) {
// 等待客戶端的連接,回傳用來通信的 Socket 物件
Socket socket = server.accept();
// 獲取客戶端的輸入流,用來讀取傳來的資料
InputStream in = socket.getInputStream();
// 將位元組流包裝成字符流
reader = new BufferedReader(new InputStreamReader(in));
// 判斷輸入流內的資料是否讀取完畢
while ((data = reader.readLine()) != null) {
	System.out.println(" 來自客戶端的問候:" + data);}
break;

使用while(true)接收多個客戶端連接

第二個while回圈讀取客戶端發送的內容

4.3.2 客戶端發送資料

示例代碼:

// 創建客戶端套接字,并連接到服務端
Socket client = new Socket("127.0.0.1", 8888);
// 創建一個可以向服務端發送資料的輸出流物件
PrintWriter writer = new PrintWriter(client.getOutputStream());
// 向服務端寫入資料
writer.write("hello,server!");   
// 清空輸出流快取
writer.flush();

這里可以使用回圈模擬不停發送資料

4.3.3 實踐練習

4.4 使用Socket類進行雙向通信

雙向通信是指服務端和客戶端都可以發送和接收資料,但是如果服務端需要同時接收多個客戶端并且通信,復雜度將大大提高

ECHO 程式是網路編程通信互動的一個經典案例,稱為回應程式,即客戶端輸入哪些內容,服務端會在這些內容前加上“ECHO”并將資訊發回給客戶端

4.4.1 雙向通信服務端

服務端關鍵代碼

// 創建服務端套接字物件
ServerSocket this.server = new ServerSocket(8888);
// 是否關閉服務端連接
boolean flag = true;
while (flag) {
     // 獲取連接的客戶端套接字物件
    socket = server.accept();
    // 獲取 socket 相關的輸入流和輸出流
    BufferedReader reader = getReader(socket);
    BufferedWriter writer = getWriter(socket);
    // 保存客戶端發送的資料
    String data = null;
}
while ((data = reader.readLine()) != null) {
// 當獲取的資訊是“bye”時,關閉流
    if ("bye".equals(data)) {
	flag = false;	//退出的標志
	//關閉相關資源 并且 break;} 
	else {System.out.println(" 來自客戶端的資料:" + data);
	// 回寫給客戶端的資料
	writer.write("echo:" + data);
	// 插入一個行分隔符,readLine() 方法用來判定字串有沒有結束
	writer.newLine();
	// 重繪輸出緩沖區
	writer.flush();      
    }
}

回圈讀取客戶端發送資料,直到發送的是bye退出

4.4.2 雙向通信客戶端

客戶端關鍵代碼

// 創建服務端套接字物件
ServerSocket this.server = new ServerSocket(8888);
// 是否關閉服務端連接
boolean flag = true;
while (flag) {
     // 獲取連接的客戶端套接字物件
     socket = server.accept();
    // 獲取 socket 相關的輸入流和輸出流
    BufferedReader reader = getReader(socket);
    BufferedWriter writer = getWriter(socket);
    // 保存客戶端發送的資料
    String data = null;
}
else {
// readLine() 方法必須讀取到行分隔符才回傳讀取,所以傳遞給輸入流的字串必須
包含行分隔符
System.out.println(" 客戶端輸出的資料 --->\t" + data);
writer.write(data);
// 插入一個行分隔符作為內容結束的標識
writer.newLine();
// 清慷訓沖區
writer.flush();
// 讀取服務端回傳的資料
System.out.println(" 服務器回應的資料 --->\t " + reader.readLine());
}

4.4.3 TCP雙向通信

說明:

  • 以上雙向通信案例僅僅是客戶端發送一條,然后馬上接收(讀取)服務端回傳的資料,并不能實作自由聊天,隨意發送和接收
  • 這是因為讀取和發送資料時受制于主執行緒約束,因為讀取資料時采用回圈讀取,會占據主執行緒資源,此時無法進行其他操作
  • 如果想實作自由雙向通信功能,需要在服務端和客戶端分別結合多執行緒功能進行實作,但是難度相應增加很多

4.4.4 實踐練習

總結:

網路中通過IP地址可以定位到具體設備,通過埠可以和設備上的不同軟體進行通信,Java中使用InetAddress類代表IP地址

基于TCP通信服務端步驟為

  1. 服務端創建ServerSocket,并指明通信埠號
  2. 呼叫serverSocket物件accept方法,等待客戶端連接,回傳Socket物件
  3. 從Socket物件中獲取輸入流、輸出流進行讀取或發送資料
  4. 關閉相關資源

基于TCP通信客戶端步驟為

  1. 創建Socket物件,指明連接的服務端IP和埠
  2. 從Socket物件中獲取輸入流、輸出流進行讀取或發送資料
  3. 關閉相關資源

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/152026.html

標籤:其他

上一篇:男默女淚!全網瘋傳的華為內部網路協議神仙筆記究竟有何魅力?

下一篇:win10右鍵檔案夾無反應

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more