test

package com.yunling.mediacenter.server;

public class HelloWorld {
	private PeerGroup netgroup = null;
	private Enumeration ae = null; // 记录发现的对等体广告。

	public static void main(String[] args) {
		HelloWorld myapp = new HelloWorld();
		myapp.startJxta();
		System.exit(0);
	}

	public void startJxta() {
		try {
			netgroup = new NetPeerGroupFactory().getInterface();

		} catch (PeerGroupException e) {
			e.printStackTrace();
		}
		// 从NetPeerGroup获得发现服务
		DiscoveryService hdisco = netgroup.getDiscoveryService();
		ae = findPeerGroup(hdisco, "Name", "HelloWorld");
		if (ae != null && ae.hasMoreElements()) {
			System.out.println("找到HelloWorld对等组");
			joinPeerGroup(netgroup, (PeerGroupAdvertisement) ae.nextElement());// 找到目标对等组,加入
			System.out.println("加入HelloWorld对等组成功!!!");
		} else {
			System.out.println("没有找到HelloWorld对等组,则创建,在创建中......");
			createNewPeerGroup(netgroup, "HelloWorld", "HelloWorld,Inc");// 没有找到目标对等组,创建
			System.out.println("创建HelloWorld对等组成功!!!");
		}
		System.exit(-1);
	}

	private Enumeration findPeerGroup(DiscoveryService dis, String key,
			String name) {
		int count = 3; // 试图发现的最高次数
		int timeout = 3000;
		Enumeration advs = null;
		// 循环直到我们发现helloWorld对等组或是直到我们达到了试图预期发现的次数。
		while (count-- > 0) {
			try {
				// 第一次搜索对等体的本地缓存来查找helloWorld对等组通告。
				// 通过NetPeerGroup组提供的发现服务发现"Name"属性为"helloWorld"的对等组
				advs = dis.getLocalAdvertisements(DiscoveryService.GROUP, key,
						name);
				// 如果发现helloWorld对等组通告,该方法完成,退出循环。
				if ((advs != null) && advs.hasMoreElements()) {
					break;
				}
				// 如果我们没有在本地找到它,便发送发现远程请求。
				// 参数依次为要查找的对等体ID,为空时不以此为发现条件;发现的通告类型,取值还有PEER,和ADV;
				// 要发现的通告属性名称;属性取值;需获取的最大通告数量;发现监听器
				dis.getRemoteAdvertisements(null, DiscoveryService.GROUP, key,
						name, 1, null);
				// 线程延时一下等待对等体內该发现请求。
				try {
					Thread.sleep(timeout);
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
		return advs;
	}

	// 如果不存在目标对等组,则创建目标对等组
	private PeerGroup createNewPeerGroup(PeerGroup netpg, String name,
			String desc) {
		PeerGroup result = null;
		try {
			// 创建一个新的对等组helloWorld
			// 通过NetPeerGroup获得一个一般对等组的通告。
			ModuleImplAdvertisement implAdv = netpg
					.getAllPurposePeerGroupImplAdvertisement();
			// 通过NetPeerGroup创建一个新的对等组,JXTA会自行发布该对等组通告,
			// 参数依次为对等组ID,通告,组名,描述
			result = netpg.newGroup(IDFactory.newPeerGroupID(), implAdv, name,
					desc);
		} catch (Exception e) {
			e.printStackTrace();
		}
		return result;
	}

	// 加入对等组
	private PeerGroup joinPeerGroup(PeerGroup netpg,
			PeerGroupAdvertisement pgAdv) {
		PeerGroup result = null;
		try {
			// 加入该对等组,由于该通告已经发布,JXTA不会再行发布。
			result = netpg.newGroup(pgAdv);
		} catch (PeerGroupException e) {
			e.printStackTrace();
		}
		return result;
	}
}package com.yunling.mediacenter.server;

public class HelloWorld {
	private PeerGroup netgroup = null;
	private Enumeration ae = null; // 记录发现的对等体广告。

	public static void main(String[] args) {
		HelloWorld myapp = new HelloWorld();
		myapp.startJxta();
		System.exit(0);
	}

	public void startJxta() {
		try {
			netgroup = new NetPeerGroupFactory().getInterface();

		} catch (PeerGroupException e) {
			e.printStackTrace();
		}
		// 从NetPeerGroup获得发现服务
		DiscoveryService hdisco = netgroup.getDiscoveryService();
		ae = findPeerGroup(hdisco, "Name", "HelloWorld");
		if (ae != null && ae.hasMoreElements()) {
			System.out.println("找到HelloWorld对等组");
			joinPeerGroup(netgroup, (PeerGroupAdvertisement) ae.nextElement());// 找到目标对等组,加入
			System.out.println("加入HelloWorld对等组成功!!!");
		} else {
			System.out.println("没有找到HelloWorld对等组,则创建,在创建中......");
			createNewPeerGroup(netgroup, "HelloWorld", "HelloWorld,Inc");// 没有找到目标对等组,创建
			System.out.println("创建HelloWorld对等组成功!!!");
		}
		System.exit(-1);
	}

	private Enumeration findPeerGroup(DiscoveryService dis, String key,
			String name) {
		int count = 3; // 试图发现的最高次数
		int timeout = 3000;
		Enumeration advs = null;
		// 循环直到我们发现helloWorld对等组或是直到我们达到了试图预期发现的次数。
		while (count-- > 0) {
			try {
				// 第一次搜索对等体的本地缓存来查找helloWorld对等组通告。
				// 通过NetPeerGroup组提供的发现服务发现"Name"属性为"helloWorld"的对等组
				advs = dis.getLocalAdvertisements(DiscoveryService.GROUP, key,
						name);
				// 如果发现helloWorld对等组通告,该方法完成,退出循环。
				if ((advs != null) && advs.hasMoreElements()) {
					break;
				}
				// 如果我们没有在本地找到它,便发送发现远程请求。
				// 参数依次为要查找的对等体ID,为空时不以此为发现条件;发现的通告类型,取值还有PEER,和ADV;
				// 要发现的通告属性名称;属性取值;需获取的最大通告数量;发现监听器
				dis.getRemoteAdvertisements(null, DiscoveryService.GROUP, key,
						name, 1, null);
				// 线程延时一下等待对等体內该发现请求。
				try {
					Thread.sleep(timeout);
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
		return advs;
	}

	// 如果不存在目标对等组,则创建目标对等组
	private PeerGroup createNewPeerGroup(PeerGroup netpg, String name,
			String desc) {
		PeerGroup result = null;
		try {
			// 创建一个新的对等组helloWorld
			// 通过NetPeerGroup获得一个一般对等组的通告。
			ModuleImplAdvertisement implAdv = netpg
					.getAllPurposePeerGroupImplAdvertisement();
			// 通过NetPeerGroup创建一个新的对等组,JXTA会自行发布该对等组通告,
			// 参数依次为对等组ID,通告,组名,描述
			result = netpg.newGroup(IDFactory.newPeerGroupID(), implAdv, name,
					desc);
		} catch (Exception e) {
			e.printStackTrace();
		}
		return result;
	}

	// 加入对等组
	private PeerGroup joinPeerGroup(PeerGroup netpg,
			PeerGroupAdvertisement pgAdv) {
		PeerGroup result = null;
		try {
			// 加入该对等组,由于该通告已经发布,JXTA不会再行发布。
			result = netpg.newGroup(pgAdv);
		} catch (PeerGroupException e) {
			e.printStackTrace();
		}
		return result;
	}
}
  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值