`
airshiplay
  • 浏览: 43772 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

java ,多播

    博客分类:
  • Java
阅读更多

同样的代码!为何在不同的机器是不同的结果!
A机器可以接收  自己和别人发送的 多播。
B机器就只接受别人发来的。自己的不接收。

import java.io.IOException;
import java.net.DatagramPacket;
import java.net.InetAddress;
import java.net.InetSocketAddress;
import java.net.MulticastSocket;
import java.net.SocketAddress;
import java.net.SocketTimeoutException;
import java.net.URI;
import java.net.URISyntaxException;
import java.net.UnknownHostException;

class MulticastRunnable implements Runnable {
	private String url = "multicast://239.255.4.3:6155";
	private MulticastSocket mcast;
	static int idGenerator = 0;
	int id;
	public MulticastRunnable(String url) {
		this.url = url;
	}
	public MulticastRunnable() {
	}
	public void run (){
		id = ++idGenerator;
                InetAddress inetAddress;
        SocketAddress sockAddress;
		try {
			URI multicastURI;
			multicastURI = new URI(url);
			inetAddress = InetAddress.getByName(multicastURI.getHost());
			sockAddress=new InetSocketAddress(inetAddress, multicastURI.getPort());
			mcast=new MulticastSocket(multicastURI.getPort());
	        mcast.setLoopbackMode(false);
	        mcast.setTimeToLive(10);
	        mcast.joinGroup(inetAddress);
	        mcast.setSoTimeout(10);
	        
	        byte[] buf=new byte[8192];
	        DatagramPacket packet=new DatagramPacket(buf,0,buf.length);
	        while(true) {
	        	// advertize self
	        	String info = "Multicast Client [" +id + "] send a packet.";
	        	System.out.println("debug info : " + info);
	        	byte[] data=info.getBytes();
                DatagramPacket sendPacket=new DatagramPacket(data,0,data.length,sockAddress);
                mcast.send(sendPacket);
                
                try {
		        	mcast.receive(packet);
		        	if(packet.getLength()>0){
	                    String str=new String(packet.getData(),packet.getOffset(),packet.getLength());
	                    System.out.println("*********"+str);
	                }
                } catch(SocketTimeoutException se){
                    // ignore
            } 
                
                try {
					Thread.sleep(5000);
				} catch (InterruptedException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
	        }
        } catch (UnknownHostException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
        catch (URISyntaxException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
        catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}

public class BeginnerTest {
	public static void main(String[] args) throws InterruptedException {
    	for (int i = 0; i < 2; ++i) {
    		Thread t = new Thread(new MulticastRunnable());
    		t.start();
    	}
    }

}




网卡具有如下的几种工作模式:

  1. 广播模式(broadcastmodel):它的物理地址(mac)地址是0xffffff的帧为广播帧,工作在广播模式的网卡接收广播帧。
  2. 多播传送(multicastmodel):多播传送地址作为目的物理地址的帧可以被组内的其它主机同时接收,而组外主机却接收不到。但是,如果将网卡设置为多播传送模式,它可以接收所有的多播传送帧,而不论它是不是组内成员。
  3. 直接模式(directmodel):工作在直接模式下的网卡只接收目的地址与自己MAC地址匹配的帧。
  4. 混杂模式(promiscuousmodel):工作在混杂模式下的网卡接收所有的流过网卡的帧,抓包捕获程序就是在这种模式下运行的。


网卡的缺省工作模式包含广播模式直接模式 ,即它只接收广播帧和发给自己的帧。如果采用混杂模式,一个站点的网卡将接受同一网络内所有站点所发送的数据包这样就可以到达对于网络信息监视捕获的目的。

 

分享到:
评论

相关推荐

    JGroups(Java多播通讯框架) v4.0.0.CR1.zip

    JGroups(Java多播通讯框架)简介 JGroups是一个可靠的群组通讯Java工具包。它基于IP组播(IP multicast),但在可靠性,组成员管理上对它作了扩展。 JGroups的可靠性体现在: 1,对所有接收者的消息的无丢失传输...

    Java多播通讯框架 JGroups

    Java多播通讯框架JGroups是Java开发者用于构建高可用、高性能和可伸缩的集群通信系统的重要工具。它提供了一套全面的协议栈,能够处理网络中的节点发现、消息传递、故障检测和恢复等问题,从而使得开发分布式应用变...

    JAVA源码Java多播通讯框架JGroups

    JAVA源码Java多播通讯框架JGroups

    java资源Java多播通讯框架JGroups

    java资源Java多播通讯框架 JGroups提取方式是百度网盘分享地址

    Java组播代码

    Java组播技术是一种网络通信方式,它允许一台或多台设备(称为组播组成员)接收来自单个数据源的相同数据流。这种技术在需要高效地向多个接收者广播信息的场景中非常有用,比如在线视频流、实时股票报价或者分布式...

    java源码:Java多播通讯框架 JGroups.zip

    java源码:Java多播通讯框架 JGroups.zip

    Java多播通讯框架 JGroups.7z

    Java多播通讯框架 JGroups.7z

    JmDNS 轻量级的Java多播DNS实现

    一款强大的开源Java库,它实现了多播DNS协议(Multicast DNS, mDNS),使得无需依赖集中式DNS服务器,即可在同一局域网内的设备间进行服务发现与通信

    Java程序播放mp3

    Java程序播放mp3是利用Java编程语言来实现的多媒体功能,特别是针对音频文件中的MP3格式。在Java中,没有内置的直接支持MP3播放的API,因此开发人员需要依赖第三方库来处理这类任务。本项目就是基于一个名为JLayer的...

    Java 图片播放 音乐播放

    总的来说,实现这个项目需要对Java基础、Swing或JavaFX界面编程、JMF音乐播放以及多线程有深入理解。设计良好的用户界面可以使应用更具吸引力,而适当的错误处理和性能优化则能提升用户体验。记住,良好的代码结构和...

    java网页视频播放

    综上所述,这个项目涵盖了Java Web开发的多个层面,从HTML5和Flash的前端视频播放,到Java后端的视频服务,再到Eclipse开发环境下的项目组织和管理。通过深入理解和实践这些知识点,开发者可以构建出高效、灵活的...

    java实现简单直播系统

    在Java中实现一个简单的直播系统是一项复杂而有趣的任务,它涉及到多个关键的技术点。下面将详细阐述这个过程中可能涉及的主要知识点: 1. **网络编程**:直播系统的基础是网络通信,Java中的Socket编程或者NIO(非...

    Java实现的视频播放程序源码

    4. **多线程**:为了实现流畅的播放体验,程序可能使用多线程来分离播放任务和用户界面更新。播放线程负责解码和播放,而主线程处理用户界面的事件,确保UI的响应性。 5. **缓冲机制**:视频播放器通常会有预加载和...

    java写的飞鸽传书(用多播+udp+tcp实现)

    《Java实现的飞鸽传书:多播、UDP与TCP技术详解》 在信息技术日新月异的时代,数据传输成为了日常工作中不可或缺的一部分。Java作为一款跨平台的编程语言,其强大的网络通信能力使得开发者能够轻松地构建各种网络...

    java多组播中传递对象

    Java多组播是一种在网络通信中高效广播数据的技术,它允许数据包被同时发送到多个接收者,而无需为每个接收者单独发送。在本场景中,我们关注的是如何使用Java来实现在多组播中传递对象。这通常涉及到网络编程、序列...

    基于Java的多播通讯框架 JGroups.zip

    《基于Java的多播通讯框架JGroups深度解析》 在Java开发中,高效、可靠的通信框架是构建分布式系统的关键组成部分。JGroups就是这样一个强大的工具,它专注于实现进程间的多播通信,提供了一套完整的解决方案来解决...

    基于Java的源码-多播通讯框架 JGroups.zip

    标题"基于Java的源码-多播通讯框架 JGroups.zip"指出,这个压缩包包含的是一个用Java语言实现的多播通信框架——JGroups。多播通信是一种网络通信方式,允许一个消息同时被多个接收者接收,非常适合在分布式系统中...

    Java实现视频播放功能.rar

    在Java编程环境中,实现视频播放功能是一项常见的任务,特别是在开发桌面应用程序或Web应用程序时。Java提供了多种库和API,使得开发者能够集成视频播放功能。在这个“Java实现视频播放功能”的项目中,我们可以深入...

    java播放pcm文件

    三、处理多声道和不同采样率 如果PCM文件是立体声或具有不同的采样率,可能需要对音频数据进行适当的处理。例如,可以使用`AudioFormat.Encoding.PCM_SIGNED`指定数据类型,根据声道数设置`channels`参数,根据位...

    java播放mp3/ogg/ape/flac音乐

    在Java编程环境中,播放MP3、OGG、APE和FLAC等音频格式的音乐涉及到音频处理和播放技术。本文将详细介绍如何使用Java实现这一功能,同时也会提及一些相关的开源工具和库。 首先,Java提供了内置的`javax.sound....

Global site tag (gtag.js) - Google Analytics