In this example we are going to explain how to use MulticastSocket in Java, in order to enable a server to easily send information to multiple clients, which are all connected to the same port and address. We will describe the whole process, by creating both the server and the client, and guide you through the main concepts that need to be understood to create this type of applications.

1. MulticastSocket Server

We are going to use a DatagramSocket,  to enable the server to send packets of information to the client/clients. A datagram, by definition, is “an independent, self-contained message sent over the network whose arrival, arrival time, and content are not guaranteed”. Essentially, we are opening a DatagramSocket in order to send DatagramPacket messages to the client. We are using the datagram classes (instead of standard sockets) because they allow us to broadcast information to multiple clients, that are all connected to aMulticastSocket.

Let’s see the code of the server:

MulticastSocketServer.java

01 import java.io.IOException;
02 import java.net.DatagramPacket;
03 import java.net.DatagramSocket;
04 import java.net.InetAddress;
05 import java.net.UnknownHostException;
06  
07 public class MulticastSocketServer {
08      
09     final static String INET_ADDR = "224.0.0.3";
10     final static int PORT = 8888;
11  
12     public static void main(String[] args) throws UnknownHostException, InterruptedException {
13         // Get the address that we are going to connect to.
14         InetAddress addr = InetAddress.getByName(INET_ADDR);
15       
16         // Open a new DatagramSocket, which will be used to send the data.
17         try (DatagramSocket serverSocket = new DatagramSocket()) {
18             for (int i = 0; i < 5; i++) {
19                 String msg = "Sent message no " + i;
20  
21                 // Create a packet that will contain the data
22                 // (in the form of bytes) and send it.
23                 DatagramPacket msgPacket = new DatagramPacket(msg.getBytes(),
24                         msg.getBytes().length, addr, PORT);
25                 serverSocket.send(msgPacket);
26       
27                 System.out.println("Server sent packet with msg: " + msg);
28                 Thread.sleep(500);
29             }
30         catch (IOException ex) {
31             ex.printStackTrace();
32         }
33     }
34 }

One thing that we need to take into consideration here, is that there are specific addresses that allow us to use a MulticastSocket are limited, specifically in the range of 224.0.0.0 to 239.255.255.255. Some of them are reserved, like 224.0.0.0. The address that we are using, 224.0.0.3, can be used safely.

2. MulticastSocket Client

Regarding the client, we are going to move a little bit differently. We are going to create a client class, that will accept incoming messages from the server, and then we are going to duplicate this class. The point here is that by using the same code, we can connect to the server seamlessly, while having as many clients as we like.

Let’s see the code of the client:

MulticastSocketClient.java

01 import java.io.IOException;
02 import java.net.DatagramPacket;
03 import java.net.InetAddress;
04 import java.net.MulticastSocket;
05 import java.net.UnknownHostException;
06  
07 public class MulticastSocketClient {
08      
09     final static String INET_ADDR = "224.0.0.3";
10     final static int PORT = 8888;
11  
12     public static void main(String[] args) throws UnknownHostException {
13         // Get the address that we are going to connect to.
14         InetAddress address = InetAddress.getByName(INET_ADDR);
15          
16         // Create a buffer of bytes, which will be used to store
17         // the incoming bytes containing the information from the server.
18         // Since the message is small here, 256 bytes should be enough.
19         byte[] buf = new byte[256];
20          
21         // Create a new Multicast socket (that will allow other sockets/programs
22         // to join it as well.
23         try (MulticastSocket clientSocket = new MulticastSocket(PORT)){
24             //Joint the Multicast group.
25             clientSocket.joinGroup(address);
26       
27             while (true) {
28                 // Receive the information and print it.
29                 DatagramPacket msgPacket = new DatagramPacket(buf, buf.length);
30                 clientSocket.receive(msgPacket);
31  
32                 String msg = new String(buf, 0, buf.length);
33                 System.out.println("Socket 1 received msg: " + msg);
34             }
35         catch (IOException ex) {
36             ex.printStackTrace();
37         }
38     }
39 }

First, we start the client, which will keep waiting for incoming packets of information. As soon as we start the server, it will send the information packets and the client will receive them and print the information on the screen.

Server Output

1 Server sent packet with msg: Sent message no 0
2 Server sent packet with msg: Sent message no 1
3 Server sent packet with msg: Sent message no 2
4 Server sent packet with msg: Sent message no 3
5 Server sent packet with msg: Sent message no 4

Client Output

1 Socket 1 received msg: Sent message no 0
2 Socket 1 received msg: Sent message no 1
3 Socket 1 received msg: Sent message no 2
4 Socket 1 received msg: Sent message no 3
5 Socket 1 received msg: Sent message no 4

In order to use multiple clients, just create anew Java project and copy-paste the code of the client, but change the output to Socket 2instead of Socket 1. You will see that when the server runs, the messages will be sent to both clients, and both clients will print the same results (except for the socket number part). Take a look at this screenshot here. We are running the first client through eclipse, the second through the command line, and the server through the command line as well.

Running a server and 2 clients.

3. Download the project

This was an example of MulticastSocket usage in Java.

Download
You can download the full source code of this example here : MulticastSocketServerMulticastSocketClient

reference from:

http://examples.javacodegeeks.com/core-java/net/multicastsocket-net/java-net-multicastsocket-example/

java.net.MulticastSocket Example--reference的更多相关文章

  1. 自己挖坑自己跳 之JsonMappingException: (was java.lang.NullPointerException) (through reference chain:)

    在Web项目中,我们经常会设计一些与界面相对应的JavaBean作为Entity,而为了兼容前台传入的空值,有些字段我们会用包装类型而不是基本类型.可是往往我的Entity已经设计完成,很多时候我们会 ...

  2. Java中各种引用(Reference)解析

    目录 1,引用类型 2, FinalReference 2.1, Finalizer 3, SoftReference 4, WeakReference 5, PhantomReference 6, ...

  3. Java密码体系结构简介:Java Cryptography Architecture (JCA) Reference Guide

    来自Java官方的文档,作备忘使用. 简介: Java平台非常强调安全性,包括语言安全,密码学,公钥基础设施,认证,安全通信和访问控制. JCA是平台的一个主要部分,包含一个“提供者”体系结构和一组用 ...

  4. java 方法引用(method reference)

    it -> it != null等价于Objects::nonNull

  5. java之DatagramSocket、DatagramPackage丶MulticastSocket 广播学习

    1.基本概念: a.DatagramPacket与DatagramSocket位于java.net包中 b.DatagramPacket表示存放数据的数据报,DatagramSocket表示接受或发送 ...

  6. 理解java reference

    Java世界泰山北斗级大作<Thinking In Java>切入Java就提出“Everything is Object”.在Java这个充满Object的世界中,reference是一 ...

  7. java组播MulticastSocket

    在单播模式中有服务器端和客户端之分,而组播模式与单播模式不同,每个端都是以路由器或交换机做为中转广播站,任意一端向路由器或交换机发送消息,路由或交换机负责发送其他节点,每个节点都是同等的.所以在编程模 ...

  8. Java基本功—Reference

    这是一篇一年多之前便已写就的文章,那时,因为很多Java程序员只求追随新生的事物,却连基本的概念都没有,很多讨论中,很明显是基本功不过硬,于是萌生写一个系列文章,讨论Java的基本功,下面便是在这个想 ...

  9. Java Reference & ReferenceQueue一览

    Overview The java.lang.ref package provides more flexible types of references than are otherwise ava ...

随机推荐

  1. OC - 16.大文件下载

    大文件下载注意事项 若不对下载的文件进行转存,会造成内存消耗急剧升高,甚至耗尽内存资源,造成程序终止. 在文件下载过程中通常会出现中途停止的状况,若不做处理,就要重新开始下载,浪费流量. 大文件下载的 ...

  2. 【C++学习之路】组合类的构造函数

    1 #include <iostream> using namespace std; class A { public: A(){ cout << "调用A无参&qu ...

  3. nodejs 初学笔记

    首先到nodejs的官网安装nodejs,地址nodejs.org,网站第一页会根据你的电脑系统推荐你适合的版本,下载,不断next,在cmd中输入 node -v 可以看到版本的话,即安装成功. 说 ...

  4. [javascript]事件冒泡处理

    <!DOCTYPE html> <html> <head> <style type="text/css"> #box1 { widt ...

  5. python学习第十八天 --文件操作

    这一章节主要讲解文件操作及其文件读取,缓存,文件指针. 文件操作 (1)文件打开:open(filepath,filemode) filepath:要打开文件的路径 filemode:文件打开的方式 ...

  6. 日志收集框架 Exceptionless

    日志收集框架 Exceptionless 前言 从去年就答应过Eric(Exceptionless的作者之一),在中国会帮助给 Exceptionless 做推广,但是由于各种原因一直没有做这件事情, ...

  7. codevs 1198 国王游戏

    传送门 题目描述 Description 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n位 ...

  8. linux ftp 搭建和相关问题解决

    1. 查看是否安装vsftprpm –qa|grep vsftpd如果出现 vsftpd-2.0.5-16.el5_5.1 说明已经安装 vsftp 安装vsftpyum -y install vsf ...

  9. 用于 Visual Studio 和 ASP.NET 的 Web 应用程序项目部署常见问题

    https://msdn.microsoft.com/zh-cn/library/ee942158(v=vs.110).aspx#can_i_exclude_specific_files_or_fol ...

  10. 【HDOJ】2424 Gary's Calculator

    大数乘法加法,直接java A了. import java.util.Scanner; import java.math.BigInteger; public class Main { public ...