java使用MulticastSocket实现组播

 更新时间:2019年01月05日 13:15:08   作者:穆穆里  
这篇文章主要为大家详细介绍了java使用MulticastSocket实现组播,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

组播是一种允许源进程将数据包发送到多个目标进程的网络技术。组播源将数据包发送到特定组播组,只有属于该组播组的进程才能接收到数据包。这些进程可以是在同一个物理网络,也可以来自不同的物理网络(只要有组播路由器支持)。

组播分为无连接和面向连接组播,但是基本的组播机制是无连接的,我们这里所讲的也是无连接组播。

我们说过使用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实现组播的要点如下:

接收方:加入组播组;
发送方:发送包含组地址的数据报。

顺便提一下组播实现私信的做法:我们可以在消息头部加上指定接收者地址,然后使用组播的方式发送,关键在接收的时候检查该地址,如果跟匹配该地址,就接收并处理;如果不匹配当然就抛弃。当然这明显有安全问题,以后找到解决办法或者单播机制再另写一篇博文了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 关于 Java 的数据结构链表

    关于 Java 的数据结构链表

    这篇文章主要介绍了关于 Java 的数据结构链表的相关资料,需要的朋友可以参考下面文章内容
    2021-09-09
  • Spring整合Mycat2的具体过程详解

    Spring整合Mycat2的具体过程详解

    这篇文章主要给大家介绍Springboot整合Mycat2的具体过程,文中有详细的图解过程,感兴趣的小伙伴可以跟着小编一起来学习
    2023-05-05
  • Java自动拆箱空指针异常的解决

    Java自动拆箱空指针异常的解决

    这篇文章主要介绍了Java自动拆箱空指针异常的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • Java Map 通过 key 或者 value 过滤的实例代码

    Java Map 通过 key 或者 value 过滤的实例代码

    这篇文章主要介绍了Java Map 通过 key 或者 value 过滤的实例代码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-06-06
  • JavaWeb详细讲述Cookie和Session的概念

    JavaWeb详细讲述Cookie和Session的概念

    web开发阶段我们主要是浏览器和服务器之间来进行交互。浏览器和服务器之间的交互就像人和人之间进行交流一样,但是对于机器来说,在一次请求之间只是会携带着本次请求的数据的,但是可能多次请求之间是会有联系的,所以提供了会话机制
    2022-06-06
  • Java使用阻塞队列控制线程通信的方法实例详解

    Java使用阻塞队列控制线程通信的方法实例详解

    这篇文章主要介绍了Java使用阻塞队列控制线程通信的方法,结合实例形式详细分析了java使用阻塞队列控制线程通信的相关原理、方法及操作注意事项,需要的朋友可以参考下
    2019-09-09
  • java本机内存分配Native memory allocation mmap失败问题解决

    java本机内存分配Native memory allocation mmap失败问题解决

    这篇文章主要介绍了java本机内存分配Native memory allocation mmap失败问题解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • 详解Java变量与常量

    详解Java变量与常量

    这篇文章主要介绍了Java变量与常量,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • Java动态代理的应用详解

    Java动态代理的应用详解

    本篇文章介绍了,Java动态代理的应用详解,需要的朋友参考下
    2013-05-05
  • Spring Boot的优点及项目创建步骤详解

    Spring Boot的优点及项目创建步骤详解

    这篇文章主要介绍了Spring Boot的优点及项目创建步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09

最新评论