组播是一种允许源进程将数据包发送到多个目标进程的网络技术。组播源将数据包发送到特定组播组,只有属于该组播组的进程才能接收到数据包。这些进程可以是在同一个物理网络,也可以来自不同的物理网络(只要有组播路由器支持)。
组播分为无连接和面向连接组播,但是基本的组播机制是无连接的,我们这里所讲的也是无连接组播。
我们说过使用multicastsocket类,这个类叫组播数据报套接字类,主要用来发送和接收ip组播报文。multicastsocket是datagramsocket的子类,它增加了加入和离开组播组的功能。组播组通过一个d类ip地址和一个标准udp端口号的组合来定义。d类ip地址的范围是224.0.0.0~239.255.255.255,除了224.0.0.0是保留地址,不应使用。
下面我们用一个简单的示例演示两个进程如何使用组播进行通信,这两个进程一个是发送端进程,另一个是接收端进程。
我们看代码:
sender.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
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
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
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实现组播的要点如下:
接收方:加入组播组;
发送方:发送包含组地址的数据报。
顺便提一下组播实现私信的做法:我们可以在消息头部加上指定接收者地址,然后使用组播的方式发送,关键在接收的时候检查该地址,如果跟匹配该地址,就接收并处理;如果不匹配当然就抛弃。当然这明显有安全问题,以后找到解决办法或者单播机制再另写一篇博文了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/whoami021/article/details/21337651