java组播技术.doc_第1页
java组播技术.doc_第2页
java组播技术.doc_第3页
java组播技术.doc_第4页
java组播技术.doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

在信息时代,网络技术应用已非常普通。其中非常多应用都依赖于从一个主机向多个主机或从多个主机向多个主机发送同一信息的能力,在Internet上分发的数目可能达数十万台,这些都需要更高的带宽,并且大大超出了单播的能力。一种能最大限度地利用现有带宽的重要技术是IP组播。1IP组播技术的概念 IP组播技术,是一种允许一台或多台主机(组播源)发送单一数据包到多台主机(一次的,同时的)的TCP/IP网络技术,是一点对多点的通信。在网络多媒体广播的应用中,当需要将一个节点的信号传送到多个节点时,无论是采用重复点对点通信方式,还是采用广播方式,都会严重浪费网络带宽,只有组播才是最佳的选择。组播能使一个或多个组播源只把数据包发送给特定的组播组,而只有加入该组播组的主机才能接收到数据包。2IP组播地址IP组播通信依赖于IP组播地址,在IPv4中他是个D类IP地址,范围从到55,并被划分为局部链接组播地址、预留组播地址和管理权限组播地址三类。其中,局部链接组播地址范围在55,这是为路由协议和其他用途保留的地址,路由器并不转发属于此范围的IP包;预留组播地址为55,可用于全球范围(如Internet)或网络协议;管理权限组播地址为55,可供组织内部使用,类似于私有IP地址,不能用于Internet,可限制组播范围。 3组播组使用同一个IP组播地址接收组播数据包的所有主机构成了一个主机组,也称为组播组。一个组播组的成员是随时变动的,一台主机能随时加入或离开组播组,组播组成员的数目和所在的地理位置也不受限制,一台主机也能属于几个组播组。此外,不属于某一个组播组的主机也能向该组播组发送数据包。 本文使用MulticastSocket类的实例编写组播应用,MulticastSocket类提供连接和离开组播等操作。MultiSender类清单package recmail.multiservice;import .*;import java.io.IOException;/* 该类封装了MulticastSocket类,完成了MulticastSocket类实例的创建、初始化功能,* 并提供了一个发送数据的接口.*/public class MultiSender public static final int MultiSender_Port=4099; private MulticastSocket road; private InetAddress ia; public MultiSender() try /组播地址 ia = InetAddress.getByName(8); road = new MulticastSocket(MultiSender_Port); road.joinGroup(ia); catch (UnknownHostException ex) catch (IOException ex1) public InetAddress getInetAddress() return ia; public MulticastSocket getRoad() return road; public void send(byte b) DatagramPacket dp = new DatagramPacket(b, 0, b.length, ia, MultiSender.MultiSender_Port); try road.send(dp); catch (IOException ex) ex.printStackTrace(); ImageServer类,使用上面的类发送文件数据.package recmail.multiservice;import java.io.*;import javax.swing.Timer;import java.awt.event.*;import java.awt.image.*;import java.util.*;import java.io.FileFilter;import java.io.FilenameFilter;/* 本类利用MultiSender类发送文件数据到一个组播组发送数据.*/public class ImageServer extends Thread implements ActionListener Timer timer; BufferedImage image; ArrayList streamfragments; int counter = 0; byte imagebyte; ArrayList listener; MultiSender sender; public ImageServer(ArrayList f) timer = new Timer(50, this); timer.addActionListener(this); listener = new ArrayList(); streamfragments = f; sender = new MultiSender(); timer.start(); public void addDataSwapListener(DataSwapListener dsl) listener.add(dsl); public void removeDataSwapListener(DataSwapListener dsl) listener.remove(dsl); private void processEvent() for (int i = 0; i this.listener.size(); i+) DataSwapEvent dse = new DataSwapEvent(); ( (DataSwapListener)this.listener.get(i).OnDataSendFinished(this, dse); public void actionPerformed(ActionEvent e) DataPacket dp = new DataPacket(streamfragments.get(counter).toString(); DataEntry de; try ArrayList al = dp.getDataPackets(); Thread.sleep(1000); System.out.println(streamfragments.get(counter).toString(); for (int i = 0; i = streamfragments.size() counter = 0; public void run() while (true) try this.sleep(20); catch (InterruptedException ex) public static void main(String args) String file; ArrayList al = new ArrayList(); String path = E:mzip; File f = new File(path); file = f.list(); for (int i = 0; i file.length; i+) if (filei.endsWith(jpg) | filei.endsWith(bmp) al.add(path + filei); ImageServer is = new ImageServer(al); is.start(); package recmail.multiservice;import .*;import java.io.*;import java.awt.image.*;/* 该类封装了MulticastSocket类,完成了MulticastSocket类实例的创建、初始化功能,* 并提供一个接收数据的线程,在判断接收完毕后产生事件,更新UI显示.* 该类由testFrame使用.*/public class ImageShow extends DataSwapListenerAdapter implements Runnable private InetAddress ia; private int port = 4099; private MulticastSocket road; DataSwapEvent dsevent; java.awt.image.BufferedImage bi; public ImageShow() dsevent = new DataSwapEvent(this); try ia = InetAddress.getByName(8); road = new MulticastSocket(port); road.joinGroup(ia); catch (IOException ex) public void run() byte buffer = new byteDataPacket.DataSwapSize; DatagramPacket packet = new DatagramPacket(buffer, buffer.length); DataPacket dp = new DataPacket(); while (true) packet.setLength(buffer.length); System.out.println(wait . ); try road.receive(packet); dp.Add(packet.getData(); if (dp.isFull() dsevent.setImage(dp.Gereratedata(); cessRecvFinishedEvent(dsevent); dp = new DataPacket(); catch (IOException ex) System.out.println(ex); 接收端界面类:package recmail.multiservice;import javax.swing.*;import java.awt.*;import java.awt.image.*;/* 该类使用ImageShow更新显示的图象.*/public class testFrame extends JApplet implements DataSwapListener private JPanel root; JLabel label; JImagePanel ip; java.awt.Image bi; public testFrame() initmain(); public void init() initmain(); this.setContentPane(root); ImageShow is = new ImageShow(); is.addDataSwapListener(this); Thread thread = new Thread(is, test); thread.start(); public static void main(String args) testFrame test = new testFrame(); test.go(new JFrame(); ImageShow is = new ImageShow(); is.addDataSwapListener(test); Thread thread = new Thread(is, test); thread.start(); public void go(JFrame frame) frame.setContentPane(root); frame.setSize(300, 200); frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); frame.validate(); frame.setVisible(true); public void initmain() root = new JPanel(); /label = new JLabel(); ip = new JImagePanel(); root.setLayout(new BorderLayout(5, 5); root.add(ip, BorderLayout.CENTER); public void setRefreshImage(java.awt.image.BufferedImage img) this.bi = img; ip.setImage(bi); public void paint(Graphics g) super.paint(g); public void paintComponents(Graphics g) super.paintComponents(g); Graphics g1 = root.getGraphics(); g1.drawImage(bi, 0, 0, this); public void OnDataSendFinished(Object s, DataSwapEvent e) public void OnDataRecvFinished(Objec

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论