欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java實(shí)現(xiàn)udp通訊的代碼

 更新時間:2018年09月22日 10:59:27   作者:rising1234  
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)udp通訊的代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下

需求:應(yīng)用A(通常有多個)和應(yīng)用B(1個)進(jìn)行 socket通訊,應(yīng)用A必須知道應(yīng)用B的ip地址(在應(yīng)用A的配置文件中寫死的),這個時候就必須把應(yīng)用B的ip設(shè)成固定ip(但是某些時候如更換路由后要重新設(shè)置網(wǎng)絡(luò),但是操作人員不知道這個規(guī)則),就有可能造成應(yīng)用A和應(yīng)用B無法進(jìn)行正常通訊,所以要改成應(yīng)用A動態(tài)獲取應(yīng)用B的ip地址。

經(jīng)過討論決定采用udp協(xié)議實(shí)現(xiàn),upd是一種無連接的傳輸層協(xié)議。應(yīng)用A在不知道應(yīng)用B的 ip情況下 可以使用廣播地址255.255.255.255,將消息發(fā)送到在同一廣播網(wǎng)絡(luò)上的B。從而獲取B的ip。

實(shí)現(xiàn)代碼:

B應(yīng)用為服務(wù)端:將udp監(jiān)聽放到一個線程中,當(dāng)有客戶端請求時就會進(jìn)行響應(yīng)

/**
 * udp連接,用于動態(tài)ip, pos向255.255.255.255:5060發(fā)送請求即可
 * **/
public class UdpServer extends Thread implements Runnable {
  private final int MAX_LENGTH = 1024;
  private final int PORT = 5060;
  private DatagramSocket datagramSocket;
  
  public void run() {
    try {
      init();
      while(true){
        try {
          byte[] buffer = new byte[MAX_LENGTH];
          DatagramPacket packet = new DatagramPacket(buffer, buffer.length);
          receive(packet);
          String receStr = new String(packet.getData(), 0 , packet.getLength());
          System.out.println("接收數(shù)據(jù)包" + receStr);
          byte[] bt = new byte[packet.getLength()];
          
          System.arraycopy(packet.getData(), 0, bt, 0, packet.getLength());
          System.out.println(packet.getAddress().getHostAddress() + ":" + packet.getPort() + ":" + Arrays.toString(bt));
          packet.setData(bt);
          response(packet);
          
        } catch (Exception e) {
          e.printStackTrace();
          LoggerUtil.error("udp線程出現(xiàn)異常:" + e.toString());
        }
      }
    } catch (Exception e) {
      e.printStackTrace();
    }
  }

  public void receive(DatagramPacket packet) throws Exception {
    datagramSocket.receive(packet);
  }

  public void response(DatagramPacket packet) throws Exception {
    datagramSocket.send(packet);
  }
  
  /**
   * 初始化連接
   */
  public void init(){
    try {
      datagramSocket = new DatagramSocket(PORT);
      System.out.println("udp服務(wù)端已經(jīng)啟動!");
    } catch (Exception e) {
      datagramSocket = null;
      System.out.println("udp服務(wù)端啟動失??!");
      e.printStackTrace();
    }
  }
}

客戶端:本來客戶端是使用pb來實(shí)現(xiàn)的,但是這里使用java來模擬

/***
 * UDP Client端
 ***/
public class UdpClient {
  
  private String sendStr = "hello";
  private String netAddress = "255.255.255.255";
  private final int PORT = 5060;
  
  private DatagramSocket datagramSocket;
  private DatagramPacket datagramPacket;
  
  public UdpClient(){
    try { 
      datagramSocket = new DatagramSocket();
      byte[] buf = sendStr.getBytes();
      InetAddress address = InetAddress.getByName(netAddress);
      datagramPacket = new DatagramPacket(buf, buf.length, address, PORT);
      datagramSocket.send(datagramPacket);
      
      byte[] receBuf = new byte[1024];
      DatagramPacket recePacket = new DatagramPacket(receBuf, receBuf.length);
      datagramSocket.receive(recePacket);
      
      String receStr = new String(recePacket.getData(), 0 , recePacket.getLength());
      
       //獲取服務(wù)端ip
      String serverIp = recePacket.getAdress();
    } catch (SocketException e) {
      e.printStackTrace();
    } catch (UnknownHostException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    } finally {
      // 關(guān)閉socket
      if(datagramSocket != null){
        datagramSocket.close();
      }
    }
  }
  
  public static void main(String[] args) {
    for (int i = 0; i < 100; i++) {
      new Thread(new Runnable() {
        @Override
        public void run() {
          UdpClient udpClient = new UdpClient();
        }
      }).start();
    }
  }
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringSecurity+OAuth2.0?搭建認(rèn)證中心和資源服務(wù)中心流程分析

    SpringSecurity+OAuth2.0?搭建認(rèn)證中心和資源服務(wù)中心流程分析

    OAuth?2.0?主要用于在互聯(lián)網(wǎng)上安全地委托授權(quán),廣泛應(yīng)用于身份驗(yàn)證和授權(quán)場景,這篇文章介紹SpringSecurity+OAuth2.0?搭建認(rèn)證中心和資源服務(wù)中心,感興趣的朋友一起看看吧
    2024-01-01
  • Java多線程之synchronized關(guān)鍵字的使用

    Java多線程之synchronized關(guān)鍵字的使用

    這篇文章主要介紹了Java多線程之synchronized關(guān)鍵字的使用,文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)java的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • 詳解java重載與覆寫的區(qū)別

    詳解java重載與覆寫的區(qū)別

    很多同學(xué)會重載和重寫分不清楚,這篇文章主要介紹了詳解java重載與覆寫的區(qū)別,有需要的朋友可以了解一下。
    2016-11-11
  • Java銀行取錢線程安全問題實(shí)例分析

    Java銀行取錢線程安全問題實(shí)例分析

    這篇文章主要介紹了Java銀行取錢線程安全問題,結(jié)合具體實(shí)例形式分析了java使用線程操作模擬銀行取錢的相關(guān)安全問題,需要的朋友可以參考下
    2019-09-09
  • 基于FileNotFoundException問題的解決

    基于FileNotFoundException問題的解決

    這篇文章主要介紹了基于FileNotFoundException問題的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Jenkins Host key verification failed問題解決

    Jenkins Host key verification failed問題解決

    這篇文章主要介紹了Jenkins Host key verification failed問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • Java多線程中wait?notify等待喚醒機(jī)制詳解

    Java多線程中wait?notify等待喚醒機(jī)制詳解

    這篇文章主要介紹了Java多線程中wait?notify等待喚醒機(jī)制,由于線程之間是搶占式執(zhí)行的,因此線程的執(zhí)行順序難以預(yù)知,但是實(shí)際開發(fā)中有時候我們希望合理的協(xié)調(diào)多個線程之間的執(zhí)行先后順序,所以這里我們來介紹下等待喚醒機(jī)制,需要的朋友可以參考下
    2024-10-10
  • java基礎(chǔ)的詳細(xì)了解第四天

    java基礎(chǔ)的詳細(xì)了解第四天

    這篇文章對Java編程語言的基礎(chǔ)知識作了一個較為全面的匯總,在這里給大家分享一下。需要的朋友可以參考,希望能給你帶來幫助
    2021-08-08
  • Java中的Semaphore信號量使用方法代碼實(shí)例

    Java中的Semaphore信號量使用方法代碼實(shí)例

    這篇文章主要介紹了Java中的Semaphore信號量使用方法代碼實(shí)例,Semaphore是一種基于計數(shù)的信號量,它可以設(shè)定一個閾值,基于此,多個線程競爭獲取許可信號,做自己的申請后歸還,超過閾值后,線程申請許可信號將會被阻塞,需要的朋友可以參考下
    2023-11-11
  • Java實(shí)現(xiàn)Android拼圖游戲設(shè)計過程解析

    Java實(shí)現(xiàn)Android拼圖游戲設(shè)計過程解析

    這篇文章主要介紹了Java實(shí)現(xiàn)Android拼圖游戲設(shè)計過程解析,下面文章要接受的這是一款基于 Java 開發(fā)的移動端安卓小游戲,可以作為大家在學(xué)習(xí)期間的一個小練習(xí),接下來和小編一起進(jìn)入文章學(xué)習(xí)具體內(nèi)容吧
    2022-02-02

最新評論