时间:2021-05-19
组播是一种允许源进程将数据包发送到多个目标进程的网络技术。组播源将数据包发送到特定组播组,只有属于该组播组的进程才能接收到数据包。这些进程可以是在同一个物理网络,也可以来自不同的物理网络(只要有组播路由器支持)。
组播分为无连接和面向连接组播,但是基本的组播机制是无连接的,我们这里所讲的也是无连接组播。
我们说过使用MulticastSocket类,这个类叫组播数据报套接字类,主要用来发送和接收IP组播报文。MulticastSocket是DatagramSocket的子类,它增加了加入和离开组播组的功能。组播组通过一个D类IP地址和一个标准UDP端口号的组合来定义。D类IP地址的范围是224.0.0.0~239.255.255.255,除了224.0.0.0是保留地址,不应使用。
下面我们用一个简单的示例演示两个进程如何使用组播进行通信,这两个进程一个是发送端进程,另一个是接收端进程。
我们看代码:
Sender.java
import java.net.DatagramPacket;import java.net.InetAddress;import java.net.MulticastSocket; public class Sender { public static void main(String[] args) { try { byte[] msg = new byte[] { 'h', 'e', 'l', 'l', 'o' }; InetAddress inetAddress = InetAddress.getByName("230.0.0.1");//根据主机名返回主机的IP地址 DatagramPacket datagramPacket = new DatagramPacket(msg, msg.length, inetAddress, 7777);//数据包包含消息内容,消息长度,组播IP和端口 MulticastSocket multicastSocket = new MulticastSocket(); multicastSocket.send(datagramPacket);//发送数据包 } catch (Exception exception) { exception.printStackTrace(); } }}Receiver.java
import java.net.DatagramPacket;import java.net.InetAddress;import java.net.MulticastSocket; public class Receiver { public static void main(String[] arstring) { try { MulticastSocket multicastSocket = new MulticastSocket(7777);//创建组播套接字并绑定到发送端口 InetAddress inetAddress = InetAddress.getByName("230.0.0.1"); multicastSocket.joinGroup(inetAddress);//组播套接字加入组播组 while (true) { byte[] data = new byte[100]; DatagramPacket datagramPacket = new DatagramPacket(data,data.length);//创建一个用于接收数据的数据包 multicastSocket.receive(datagramPacket);//接收数据包 System.out.println(new String(data)); } } catch (Exception exception) { exception.printStackTrace(); } }}使用MulticastSocket实现组播的要点如下:
接收方:加入组播组;
发送方:发送包含组地址的数据报。
顺便提一下组播实现私信的做法:我们可以在消息头部加上指定接收者地址,然后使用组播的方式发送,关键在接收的时候检查该地址,如果跟匹配该地址,就接收并处理;如果不匹配当然就抛弃。当然这明显有安全问题,以后找到解决办法或者单播机制再另写一篇博文了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
java单播、广播、组播详解及实例代码在当前网络通信中(TCP/IP也不例外)有三种通信模式:单播、广播、组播(又叫多播,个人感觉叫多播描述的有点不恰当),其中
java基础知识之网路通信总结在这篇文章里,我们主要讨论如何使用Java实现网络通信,包括TCP通信、UDP通信、多播以及NIO。 TCP连接 TCP的基础
本文实例讲述了Java线程组操作。分享给大家供大家参考,具体如下:一点睛1Java使用ThreadGroup来表示线程组,它可以对一批线程进行分类管理,Java
RPF叫做逆向路径转发,主要用于组播环境中针对于组播源对于组播组地址的所有数据做路由检查。 Rpf是高端三维软件的一种输出格式,它存储了景深、物体通道、坐标、
igmp协议属于网络层。 IGMP协议(InternetGroupManagementProtocol)是因特网协议家族中的一个组播协议,组播协议允许将一台主