Java連載128-UDP通信編程

来源:https://www.cnblogs.com/ruigege0000/archive/2020/07/09/13270181.html
-Advertisement-
Play Games

一、UDP編程 1.DatagramPacket特性以及構造方法 UDP是一個面向無連接的協議,因此,在通信時發送端和接收端不用建立連接。 Datagram類就相當於一個集裝箱用於封裝UDP通信中發送或者接收的數據。 構造方法: (1)DatagramPacket(byte[] buf,int le ...


一、UDP編程

1.DatagramPacket特性以及構造方法

  • UDP是一個面向無連接的協議,因此,在通信時發送端和接收端不用建立連接。
  • Datagram類就相當於一個集裝箱用於封裝UDP通信中發送或者接收的數據。
  • 構造方法:
    (1)DatagramPacket(byte[] buf,int length)
    使用該構造方法在創建DatagramPacket對象的時候指定了封裝對象的位元組數組和數據大小,沒有指定IP和埠號。這樣的對象只能用於接收端而不能用於發送端。因為發送端一定要明確指出數據的目的地(IP地址和埠號),而接收端不需要明確數據的來源,只需要接收到數據即可。
    (2)DatagramPacket(byte[] buf,int length,InetAddress addr,int port)
    使用該構造方法在創建對象的時候指定了IP地址和埠號,通常用於發送端。
    (3)DatagramPacket(byte[] buf,int offset,int length)
    用於接收端,offset該參數用於指定接收到的數據放在buf緩衝數組時是從offset開始的。
    (4)DatagramPacket(byte[] buf,int offset,int length,InetAddress addr,int port)
    結合(2)(3)就能看懂了

2.DatagramPacket常用方法

(1)InetAddress getAddress()
返回發送端或者接收端的IP地址,得看在哪一端。
(2)int getPort()
返回發送端或者接收端的埠號。
(3)bytep[] getData()
返回將要接收或者發送的數據。
(4)int getLength()
返回將要接收或者發送的數據的長度。

二、DatagramSocket

  • DatagramPacket就是數據包,DatagramSocket可以認為是運送數據包的“碼頭”

1.構造方法詳解

(1)DatagramSocket()
該構造方法用於創建發送端的DatagramSocket對象,沒有指定埠,系統會自動分配一個。
(2)DatagramSocket(int port)
既可以用於發送端又可以用於接收端。在用於接收端的時候必須指定埠號,這樣才能監聽埠。
(3)DatagramSocket(int port,InetAddress addr)
該對象適用於電腦上有多塊網卡的情形,使用時可以明確規定數據通過哪塊網卡向外發送和接收 哪塊網卡的數據。由於電腦中針對不同的網卡分配不同的IP地址,因此在創建對象的時候需要指定IP地址。

2.常用的成員方法

(1)void receive(DatagramPacket p)
將接受到的數據填充到DatagramPacket數據包中,在接收到數據之前會一直處於阻塞狀態,只有當接收到數據包的時,該方法才會返回。
(2)void send(DatagramPacket p)
放送DatagramPacket數據包,發送的數據包中包含將要發送的數據,數據的長度,遠程主機的IP地址和埠號。
(3)void close
關閉當前的Socket,通知驅動程式釋放為這個Socket保留的資源。

3.直接舉例UDP編程實例

package com.bjpowernode.java_learning;

import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;

public class D128_1_ServerTest {
 public static void main(String[] args) {
  DatagramSocket socket = null;
  DatagramPacket packet_send = null;
  DatagramPacket packet_receive = null;
  int port = 5151;                                 //伺服器監聽埠號
  try {
   socket = new DatagramSocket(port);           //創建連接對象
   System.out.println("伺服器啟動");        
   byte[] r = new byte[1024];                   //創建緩存數組
   packet_receive = new DatagramPacket(r,r.length);//創建數據包對象
   socket.receive(packet_receive);              //接收數據包
   InetAddress client_ip = packet_receive.getAddress();//客戶端地址
   int client_port = packet_receive.getPort();          //客戶端的埠號
   byte[] data = packet_receive.getData();      //客戶端位元組數據
   int len = packet_receive.getLength();        //數據有效長度
   String str1 = new String(data,0,len);        //將位元組數據轉換為字元串
   System.out.println("客戶機"+client_ip+":"+client_port+"\n發送的信息是:"+str1);
   String response = "Hello,I am Server B";
   byte[] s = response.getBytes();
   packet_send = new DatagramPacket(s,s.length,client_ip,client_port);//創建響應數據包對象
   socket.send(packet_send);
  }catch(Exception e) {
   System.out.println(e);
  }finally {
   socket.close();
  }
 }

}
 
  • 我們先運行這個伺服器端
  • 128.1
package com.bjpowernode.java_learning;

import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;

public class D128_2_ClientTest {
 public static void main(String[] args) {
  DatagramSocket socket = null;
  DatagramPacket packet_send = null;
  DatagramPacket packet_receive = null;
  String server = "127.0.0.1";                               //伺服器IP地址
  int port = 5151;                                           //伺服器埠號
  String str = "Hello,I am Client A";
  byte[] data = str.getBytes();                               //將要發送的信息轉換為位元組數組
  try {
   socket = new DatagramSocket();                         //創建連接socket對象
   InetAddress addr = InetAddress.getByName(server);      //將伺服器端的IP地址封裝成InetAddress對象
   packet_send = new DatagramPacket(data,data.length,addr,port);//創建數據包對象
   socket.send(packet_send);                              //向伺服器發送數據
   byte[] r = new byte[1024];                             //設置緩衝區
   packet_receive = new DatagramPacket(data,data.length,addr,port);//創建數據包對象
   socket.receive(packet_receive);                        //接收數據包
   byte[] response = packet_receive.getData();            //讀取數據包中的數據信息
   int len = packet_receive.getLength();                  //讀取數據長度
   String str1 = new String(response,0,len);              //將位元組數據轉換成字元串
   System.out.println("伺服器響應的信息是:"+str1);  
  }catch(Exception e) {
   System.out.println(e);
  }finally {
   socket.close();
  }
 }

}
 
  • 接下里運行客戶端程式
  • 128.2

三、源碼:

  • D128_1_ServerTest.java
  • D128_2_ClientTest.java
  • https://github.com/ruigege66/Java/blob/master/D128_1_ServerTest.java
  • https://github.com/ruigege66/Java/blob/master/D128_2_ClientTest.java
  • CSDN:https://blog.csdn.net/weixin_44630050
  • 博客園:https://www.cnblogs.com/ruigege0000/
  • 歡迎關註微信公眾號:傅里葉變換,個人賬號,僅用於技術交流,後臺回覆“禮包”獲取Java大數據學習視頻禮包
  • 127.59

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 綜合來講,Web前端培訓分為HTML5+CSS3、JS交互設計、移動端、伺服器、前端框架、小程式六大模塊,下麵就為大傢具體介紹每個階段學什麼。 第一階段前端核心基礎,讓學員掌握前端基礎知識包括HTML5與CSS的基礎知識和代碼的撰寫會學習PC端網站佈局以及jQuery框架。 第二階段HTML5 + ...
  • web前端現在是一個很熾手可熱的職業,現在前端工程師到底能賺多少錢?月薪3000和30000的工程師到底差在哪?前端的待遇為什麼這麼高? 今天我們來具體分析一下。 web前端的薪資是多少? 我們先用三個數據瞭解一下。 web前端在北京地區的薪資: 北京前端開發工程師平均工資:¥ 18690/月,取自 ...
  • 開發一個 IDE 很難麽?這或許是件很難的事情,但當我們參考 VSCode 的技術構架來看,整個開發流程就會平滑順暢很多,從內核開發、代碼編輯器、視圖結構到插件系統,在這整個技術構架中我們可以看到很多一個 IDE 開發中需要註意的方方面面。如果你對 VSCode 深入研究過,相信可以從中頗受啟發,在 ...
  • 作者:凹凸曼 - Barrior 在 Canvas 中對文本填充水平或垂直的線性漸變可以輕易實現,而帶角度的漸變就複雜很多;就好像下麵這樣,假設文本矩形寬為 W, 高為 H, 左上角坐標為 X, Y。 猜想與答案 給出兩個答案: 正確答案是圖二,因為這樣得出來的坐標生成的漸變最緊接文本矩形邊界,它的 ...
  • Mybatis的sql映射 添加: boolean addUser(User user); <insert id="addUser" parameterType="User"> insert into Users(uname,upass) values(#{uname},#{upass}) </in ...
  • 問題起源 使用SpringCloud構建項目時,使用Swagger生成相應的介面文檔是推薦的選項,Swagger能夠提供頁面訪問,直接在網頁上調試後端系統的介面, 非常方便。最近卻遇到了一個有點困惑的問題,演示介面示例如下(原有功能介面帶有業務實現邏輯,這裡簡化了介面): /** * @descri ...
  • 多線程與非同步 非同步是目的,而多線程是實現這個目的的方法。 1 Java J.U.C線程調度 JDK 1.5新增的java.util.concurrent包,增加了併發編程的很多類。 Executor 定義了方法execute(),用來執行一個任務 public interface Executor ...
  • 1.http:(1)當⽤戶在地址輸⼊了⽹址 發送⽹絡請求的過程是什麼 (2)http的請求⽅式 get請求 (1)⽐較便捷 缺點:不安全:明⽂ 參數的⻓度有限制 post請求 (1)⽐較安全 (2)數據整體沒有限制 (3)上傳⽂件 put(不完全的) delete(刪除 ⼀ 些信息) head(請求 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...