- 浏览: 1099383 次
- 性别:
- 来自: 北京
-
文章分类
- 全部博客 (379)
- eclipse (6)
- java基础 (21)
- opencms (4)
- tomcat (10)
- kettle (13)
- spring (7)
- 生活点滴 (3)
- linux (61)
- database (1)
- php (4)
- mac (3)
- mysql (37)
- maven (5)
- Asterisk (2)
- android (4)
- birt (2)
- hadoop (52)
- pentaho (46)
- distributed (2)
- Storm (2)
- 数据挖掘 (1)
- cassandra (0)
- spark (0)
- greenplum (3)
- R (1)
- liferay (3)
- 深度学习 (2)
- 数学 (1)
- Docker (3)
- Rancher (2)
- html (1)
- oracle (0)
- 交易 (0)
- Davinci (0)
- 大模型 (0)
最新评论
-
gujunge:
劝退。不支持两步验证登录、复制Session无效
Linux下SecureCRT的替代品:PAC Manager -
huangtianleyuan:
各位大神,有没有集成好的,请不吝赐教 qq:375249222 ...
在Web中集成Kettle -
梦行Monxin商城系统:
Dapper,大规模分布式系统的跟踪系统 -
hunter123456:
您好,请问一下,pentaho5.X 以上的版本,在服务器上建 ...
pentaho 4.8 添加 kettle 文件资源库的支持 -
hunter123456:
你好!pentaho5上 cas 单点登录,除了 修改appl ...
作为一个BI开发人员,我要发布报表,元数据,OLAP的模型到BI服务器
编辑一个java组播应用程序的过程如下
1. 创建一个用于发送和接收的MulticastSocket组播套接字对象
2. 创建一个指定缓冲区大小及组播地址和端口的DatagramPacket组播数据包对象
3. 使用组播套接字joinGroup(),将其加入到一个组播
4. 使用组播套接字的send()方法,将组播数据包对象放入其中,发送组播数据包.
或者
使用组播套接字的receive()方法,将组播数据包对象放入其中,接收组播数据包
5. 解码组播数据包提取信息,并依据得到的信息作出响应String s = new String(dp.getData(), 0, dp.getLength());
6. 重复过程4和5,即在while循环中实现。
7. 使用组播套接字的leaveGroup()方法,离开组播组;关闭组播套接字
接收组播数据包程序:
public class MulticastReceived { public static void main(String[] args) throws Exception { InetAddress group = InetAddress.getByName("224.0.0.4"); // 组播地址 int port = 4006; // 端口 MulticastSocket msr = null; try { msr = new MulticastSocket(port); // 1.创建一个用于发送和接收的MulticastSocket组播套接字对象 msr.joinGroup(group); // 3.使用组播套接字joinGroup(),将其加入到一个组播 byte[] buffer = new byte[8192]; System.out.println("接收数据包启动!(启动时间:)" + new java.util.Date() + ")"); while (true) { DatagramPacket dp = new DatagramPacket(buffer, buffer.length); // 2.创建一个指定缓冲区大小及组播地址和端口的DatagramPacket组播数据包对象 msr.receive(dp); // 4.使用组播套接字的receive()方法,将组播数据包对象放入其中,接收组播数据包 String s = new String(dp.getData(), 0, dp.getLength()); // 5.解码组播数据包提取信息,并依据得到的信息作出响应 System.out.println(s); } } catch (IOException e) { e.printStackTrace(); } finally { if (msr != null) { try { msr.leaveGroup(group); // 7.使用组播套接字的leaveGroup()方法,离开组播组 msr.close(); // 关闭组播套接字 } catch (IOException e) { } } } } }
发送组播数据包程序:
public class MulticastSender { public static void main(String[] args) throws Exception { InetAddress group = InetAddress.getByName("224.0.0.1"); // 组播地址 int port = 4000; // 端口 MulticastSocket mss = null; try { mss = new MulticastSocket(port); // 1.创建一个用于发送和接收的MulticastSocket组播套接字对象 mss.joinGroup(group); // 3.使用组播套接字joinGroup(),将其加入到一个组播 byte[] buffer = new byte[8192]; System.out.println("接收数据包启动!(启动时间:)" + new java.util.Date() + ")"); while (true) { String message = "Hello" + new java.util.Date(); byte[] buffer2 = message.getBytes(); // 2.创建一个指定缓冲区大小及组播地址和端口的DatagramPacket组播数据包对象 DatagramPacket dp = new DatagramPacket(buffer, buffer.length, group, port); // msr.receive(dp); //接收组播数据包 mss.send(dp); // 4.使用组播套接字的send()方法,将组播数据包对象放入其中,发送组播数据包 // String s = new String(dp.getData(), 0, dp.getLength()); //5.解码组播数据包提取信息,并依据得到的信息作出响应 System.out.println("发送数据包给" + group + ":" + port); Thread.sleep(1000); } } catch (IOException e) { e.printStackTrace(); } finally { if (mss != null) { try { mss.leaveGroup(group); // 7.使用组播套接字的leaveGroup()方法,离开组播组 mss.close(); // 关闭组播套接字 } catch (IOException e) { } } } } }
评论
3 楼
arthaslery
2015-12-09
4.还有一点是要在最上面加上
import java.io.*;
import java.net.*;
import java.io.*;
import java.net.*;
2 楼
arthaslery
2015-12-09
博主的程序改一改以后是很好用的
1.发送数据包的buffer2要改成buffer,然后删掉上面的buffer定义
2.组播地址224.0.0.4和224.0.0.1要改成相同的
3.发送端的socket端口不重要,但是接收端的socket端口和发送端的packet目标端口必须相同,也就是说要把4006和4000改成一样的
1 楼
戴改改
2015-05-03
发送的地址和 接受的地址不一样啊。。
一个.4一个.1;
我自己实验 用230.0.0.1 在两台机器上就没法接受了
只有在224才行。。。
一个.4一个.1;
我自己实验 用230.0.0.1 在两台机器上就没法接受了
只有在224才行。。。
发表评论
-
Java基于Runtime调用外部程序出现阻塞的解决方法
2015-12-18 20:06 1141本文实例讲述了Java基于Runtime调用外部程序出现阻 ... -
Apache Ant 实例介绍
2015-06-11 18:05 0Ant和Maven的优劣区别在这里就不再说了,在本篇,着 ... -
java线程wait和notifyAll方法的简单使用
2015-05-09 12:14 910今天温习了java线程的 ... -
KeePass密码管理与自动登录
2015-01-04 15:07 1921KeePass管理密码,后面可以使用脚本自动登录: ... -
使用jmap做java进程dump
2014-09-02 11:05 2234命令:jmap -dump:format=b,file=he ... -
apache 所有版本下载地址
2014-06-09 19:05 850http://archive.apache.org/dist/ ... -
How to build and package OpenJDK 7 on Linux
2014-05-13 22:59 1224Some pre-requisites are r ... -
java.util.ResourceBundle使用
2014-04-23 16:21 1466java.util.ResourceBundle使用详解 ... -
文件在使用FileChannel.map后不能被删除(Windows上)
2014-04-15 09:14 1133同事发现在Windows上使 ... -
LRU算法 java实现
2014-04-15 09:06 5375最简单的LRU算法实现,就是利用Java的LinkedHa ... -
log4j每个小时生成一个日志文件
2013-12-14 16:23 3543log4j.properties 属性文件 log4j ... -
扩展JAAS实现类实例级授权
2013-08-15 15:02 942转:http://www.ibm.com/developer ... -
简简单单的代码让你轻松学会动态代理
2013-08-03 19:10 1047转:http://weixiaolu.iteye.com ... -
Java NIO原理图文分析及代码实现
2013-08-03 19:04 1007转:http://weixiaolu.iteye.com/ ... -
Java的安全学习(包括加密,数字签名,证书和认证) JCA JCE
2012-04-09 00:18 4210自己作个笔记: package de ... -
JDK1.5中的线程池使用简介
2012-02-27 10:46 1226在多线程大师Doug Lea的贡献下,在JDK1.5中加入了许 ... -
面试java高级工程师、项目经理等的常见问题
2012-02-07 10:41 01、 类、对象的概念: 1) 类:具有共同属性和行为的对象 ... -
Java的ClassLoader机制解析
2012-02-05 17:31 2103JVM在加载类的时候,都 ... -
java安全管理器-SecurityManager
2012-02-03 17:15 1537当java应用程序启动时,它还没有安全管理器,应用程序可以通过 ... -
JSP包含指令include包含html文件出现乱码分析与解决
2011-08-19 09:25 2765关于JSP页面中的pageEncoding和contentTy ...
相关推荐
Java多组播是一种在网络通信中高效广播数据的技术,它允许数据包被同时发送到多个接收者,而无需为每个接收者单独发送。在本场景中,我们关注的是如何使用Java来实现在多组播中传递对象。这通常涉及到网络编程、序列...
Java UDP组播是一种在局域网或互联网上高效传播数据的方法,它允许一个发送者将消息一次性广播到多个接收者,而无需为每个接收者单独发送。这种技术在实时流媒体、多玩家游戏和分布式系统中非常常见。下面将详细阐述...
【Java的组播聊天室——图形界面】是一个利用Java编程语言构建的多用户通信系统,它基于多播技术实现,允许多个用户在同一网络环境中实时交流。这个项目的核心特性是其图形用户界面(GUI),提供了直观易用的交互...
Java组播Socket网络编程的应用场景十分丰富,例如在视频会议系统中,需要将视频和音频数据实时传输给多个客户端;在游戏开发中,通过组播技术可以实现多玩家间的即时通信。此外,在企业级应用中,组播技术也可用于...
在Java开发领域,构建一个基于组播技术的聊天室是一项具有挑战性的任务,它涉及到网络编程、多线程以及数据传输等核心概念。本项目名为“java开发的组播聊天室”,其主要特点在于利用了IP组播协议,使得信息能够高效...
Java 组播组是网络编程中的一个重要概念,它允许数据包在多个接收者之间广播,而无需逐个发送。在Java中,我们可以使用Java的多播套接字(MulticastSocket)来实现这一功能。本实例将深入讲解如何在Java中创建组播组...
本文档的作者赵文清通过基于Java网络编程与Java平台设计组播程序并进行实验,验证了在组播技术中运用Java平台的可行性。实验的成功说明Java在实现组播通信方面不仅可行,而且效率较高,这进一步表明Java网络编程在...
这个“Java 组播组中发送和接受数据实例.7z”压缩包很可能是包含了一个或多个Java程序,用于演示如何在Java中实现多播通信。 多播通信的核心在于Internet多播地址和多播组的概念。Internet多播地址属于D类IP地址...
通过实际操作,开发者可以深入理解如何在Java中实现组播通信,包括设置组播组、创建和配置MulticastSocket、以及处理数据包的发送和接收。同时,这也是一个很好的示例,展示了如何在NetBeans这样的IDE中组织和管理...
本实例将深入探讨如何在Java中实现组播数据的发送与接收。 首先,我们需要导入Java的网络编程相关包,特别是`java.net.MulticastSocket`类,这是处理组播的关键: ```java import java.net.*; ``` 发送数据到组播...
Java UDP组播群聊小程序是一种基于用户数据报协议(UDP)实现的多点通信应用,适合初学者了解网络编程和组播技术。UDP是一种无连接的传输层协议,相较于TCP,它提供了更低的延迟和更高的效率,但不保证数据的可靠...
压缩包中的"java组播编程实例"文件很可能是上述步骤的实现代码,包含了完整的组播发送和接收过程。通过分析和运行这个示例,开发者可以更好地理解Java中的组播工作原理,并将其应用到自己的项目中。 总之,Java的组...
在实际编程中,你需要创建一个MulticastSocket实例,然后调用`joinGroup()`加入组播组。接着,你可以创建一个DatagramPacket,填充数据,然后调用`send()`方法将其发送出去。在接收端,你需要创建一个同样加入了组播...
Java组播,也称为Multicast,是网络编程中一种高效的数据传输方式,尤其适用于一对多或多对多的通信场景,如视频流、实时数据广播等。在Java中,实现组播功能主要依赖于Java的Socket API,特别是`java.net....
Java聊天室是一个基于Java编程语言实现的交互式通信平台,它结合了组播和私聊功能,使得用户既能参与群组讨论,也能进行一对一的秘密对话。在这个系统中,组播技术用于实现多人同时在线聊天的功能,而私聊则确保了...
DatagramSocket用于单播通信,而MulticastSocket支持多播,适用于广播或组播场景,如视频流媒体传输。 3. **URL和URLConnection**:Java的java.net.URL类代表统一资源定位符,用于表示网络上的资源。URLConnection...
本节我们将深入探讨Java在游戏编程中的应用及其相关知识点。 一、Java语言基础 Java的基础语法是游戏编程的基石。理解类、对象、继承、封装和多态等面向对象概念至关重要。同时,熟悉异常处理、数据结构(如数组、...
基于Java网络编程中组播技术的应用研究
这个"基于java的组播组中发送和接受数据实例.zip"文件很可能包含了使用Java进行组播通信的示例代码。 **1. 多播的概念** 多播是一种IP协议,允许单个源向多个目的地发送数据,而无需为每个接收者单独发送。这与广播...
Java UDP(用户数据报协议)是Java网络编程中不可或缺的一部分,尤其在实现P2P(对等网络)软件时,其高效、无...这个实例为你提供了一个实践的起点,通过学习和运行这个代码,你可以更好地掌握Java中的UDP组播编程。