Java使用MulticastSocket实现多点广播
Java使用MulticastSocket实现多点广播
MulticastSocket可以将数据报以广播的方式发送到多个客户端。
MulticastSocket有如下3个构造方法
public MulticastSocket():使用本机默认地址,随机端口来创建MulticastSocket对象。
public MulticastSocket(int portNumber):使用本机默认地址,指定端口创建MulticastSocket对象。
public MulticastSocket(SocketAddress bindaddr):使用本机指定IP地址,指定端口来创建MulticastSocket对象。
创建MulticastSocket对象后,还炫耀将MulticastSocket加入到指定的多点广播地址,MulticastSocket使用joinGroup()方法加入指定组;使用leaveGroup()方法脱离一个组。
joinGroup(InetAddress addr);
leaveGroup(InetAddress addr);
InetAddress 类没有提供构造,而提供如下两个静态方法来获取InetAddress对象
getByName(String host):如getByName("localhost"),getByName(www.bkjia.com);
getByAddress(byte []addr):如getByAddress(new byte[]{127,0,0,1});
MulticastSocket类中有一个setTimeToLive(int ttl),当ttl为0时,指定数据报应停留在本地主机,为1时,指定数据报发送到本地局域网网,为32时,发送到本站点的网络上。为64时,发送到本地区,128时,发送到本大洲,255为全球。
- import java.io.IOException;
- import java.net.DatagramPacket;
- import java.net.InetAddress;
- import java.net.MulticastSocket;
- import java.util.Scanner;
- public class Test implements Runnable{
- MulticastSocket socket;
- DatagramPacket rece;
- byte []buffer;
- public Test()
- {
- try {
- socket=new MulticastSocket(4800);
- InetAddress addr=InetAddress.getByAddress(new byte[]{(byte)230,0,0,1});
- socket.joinGroup(addr);
- buffer=new byte[4000];
- rece=new DatagramPacket(buffer,4000);
- Thread th=new Thread(this);
- th.start();
- Scanner sc=new Scanner(System.in);
- while(sc.hasNextLine())
- {
- DatagramPacket dp=new DatagramPacket(sc.nextLine().getBytes(),sc.nextLine().getBytes().length,addr,4800);
- socket.send(dp);
- }
- } catch (Exception e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- }
- public static void main(String[] args) {
- new Test();
- }
- @Override
- public void run() {
- while(true)
- {
- try {
- socket.receive(rece);
- System.out.println(new String(buffer));
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- }
- }
上面的代码能运行,貌似有点问题,不过还是可以通讯,有时间在好好做一做,先做到这里。
评论暂时关闭