使用MulticastSocket实现多点广播

Posted ZSQ的博客

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用MulticastSocket实现多点广播相关的知识,希望对你有一定的参考价值。

原文链接:http://hbiao68.iteye.com/blog/1943354

 

使用MulticastSocket实现多点广播

 

DatagramSocket只允许数据报发送给指定的目标地址,而MulticastSocket可以将数据报以广播的方式发送到多个客户端

 

若要使用多点广播,则需要让一个数据报标有一组目标主机地址,当数据报发出后,整个组的所有所有主机都能收到该数据报。IP多点广播(或多点发送)实现了将单一信息发送到多个接受者的广播,其思想是设置一组特殊网络地址作为多点广播地址,每一个多点广播地址都被看做一个组,当客户端需要发送、接收广播信息时,加入到改组即可。

MulticastSocket既可以将数据报发送到多点广播地址,也可以接收其他主机的广播信息。

 

技术分享

 

    MulticastSocket有点像DatagramSocket,事实上MulitcastSocket是DatagramSocket的一个子类,当要发送一个数据报时,可以使用随机端口创建一个MulticastSocket,也可以在指定端口创建MulticastSocket。MulticastSocket提供了如下3个构造器。

1、MulticastSocket():使用本机默认地址、随机端口来创建MulticastSocket对象

2、MulticastSocket(int portNumber)使用本机默认地址、指定端口来创建对象

3、MulticastSocket(SocketAddress bindaddr):使用本机指定IP地址、指定端口来创建对象

 

    创建MulticastSocket对象后,还需要将该MulticastSocket加入到指定的多点广播地址,MulticastSocket使用joinGroup()方法加入指定组;使用leaveGroup()方法脱离一个组。

1、joinGroup(InetAddress multicastAddr):将该MulticastSocket加入指定的多点广播地址。

2、leaveGroup(InetAddress multicastAddr):让该MulticastSocket离开指定的多点广播地址。

 

应用程序只将数据报包发送给组播地址,路由器将确保包被发送到改组播组中的所有主机。 
组播地址:称为组播组的一组主机所共享的地址。组播地址的范围在224.0.0.0--- 239.255.255.255之间(都为D类地址 1110开头)。 

备注:如果现在有三台机器A、B、C,三台机器IP地址都不一样,A\B为server监听广播消息,C为客户端发送广播消息,个人理解是将A、B两台机器的MulticastSocket对象绑定在组播地址中的其中一个,然后C客户端发送消息的组播地址一致,则A、B就能够接收C发送的消息。

 

 

如果MulticastSocket用于接收信息则使用默认地址和随机端口即可,但是如果用来接收信息,则必须要指定端口,否则发送方无法确定发送数据报的目标端口。

 

Java代码  技术分享
  1. package hb.brodcast;  
  2.   
  3. import java.net.DatagramPacket;  
  4. import java.net.InetAddress;  
  5. import java.net.MulticastSocket;  
  6.   
  7. public class MulticastListener {  
  8.     private int port;  
  9.     private String host;  
  10.   
  11.     public MulticastListener(String host, int port) {  
  12.         this.host = host;  
  13.         this.port = port;  
  14.     }  
  15.   
  16.     public void listen() {  
  17.         byte[] data = new byte[256];  
  18.         try {  
  19.             InetAddress ip = InetAddress.getByName(this.host);  
  20.             MulticastSocket ms = new MulticastSocket(this.port);  
  21.             ms.joinGroup(ip);  
  22.             DatagramPacket packet = new DatagramPacket(data, data.length);  
  23.             //receive()是阻塞方法,会等待客户端发送过来的信息  
  24.             ms.receive(packet);  
  25.             String message = new String(packet.getData(), 0, packet.getLength());  
  26.             System.out.println(message);  
  27.             ms.close();  
  28.         } catch (Exception e) {  
  29.             e.printStackTrace();  
  30.         }  
  31.     }  
  32.   
  33.     public static void main(String[] args) {  
  34.         int port = 1234;  
  35.         String host = "224.0.0.1";  
  36.         MulticastListener ml = new MulticastListener(host, port);  
  37.         while (true) {  
  38.             ml.listen();  
  39.         }  
  40.     }  
  41. }  

 

Java代码  技术分享
  1. package hb.brodcast;  
  2.   
  3. import java.net.DatagramPacket;  
  4. import java.net.InetAddress;  
  5. import java.net.MulticastSocket;  
  6.   
  7. public class MulticastSender {  
  8.     private int port;  
  9.     private String host;  
  10.     private String data;  
  11.   
  12.     public MulticastSender(String data, String host, int port) {  
  13.         this.data = data;  
  14.         this.host = host;  
  15.         this.port = port;  
  16.     }  
  17.   
  18.     public void send() {  
  19.         try {  
  20.             InetAddress ip = InetAddress.getByName(this.host);  
  21.             DatagramPacket packet = new DatagramPacket(this.data.getBytes(), this.data.length(), ip, this.port);  
  22.             MulticastSocket ms = new MulticastSocket();  
  23.             ms.send(packet);  
  24.             ms.close();  
  25.         } catch (Exception e) {  
  26.             e.printStackTrace();  
  27.         }  
  28.     }  
  29.   
  30.     public static void main(String[] args) {  
  31.         int port = 1234;  
  32.         String host = "224.0.0.1";  
  33.         String data = "hello world.";  
  34.         System.out.println(data);  
  35.         MulticastSender ms = new MulticastSender(data, host, port);  
  36.         ms.send();  
  37.     }  
  38. }  

 

    MulticastSocket用于发送、接收数据报的方法与DatagramSocket完全一样。但MulticastSocket比DatagramSocket多了一个setTimeToLive(int ttl)方法,该ttl参数用于设置数据报最多可以跨过多少个网络,当ttl的值为0时,指定数据报应停留在本地主机;当ttl的值为1时,指定数据报发送到本地局域网;当ttl的值为32时,意味着只能发送到本站点的网络上;当ttl的值为64时,意味着数据报应保留在本地区;当ttl的值为128时,意味着数据报应保留在本大洲;当ttl的值为255时,意味着数据报可发送到所有地方;在默认情况下,该ttl的值为1。

以上是关于使用MulticastSocket实现多点广播的主要内容,如果未能解决你的问题,请参考以下文章

Android:SSDP 卡在 MulticastSocket.receive()

Android 局域网内功能模块开发,教你怎么快速获取局域网内所有IP并且进行通信------ MulticastSocket

单播广播组播的区别(转)

Python 实现udp组播

单播,组播,广播

OSPF不同的网络类型