让你的JXTA应用更加安全.建立真正你自己的私有的组!
生活随笔
收集整理的這篇文章主要介紹了
让你的JXTA应用更加安全.建立真正你自己的私有的组!
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
在JXTA應(yīng)用中有對(duì)等組的概念,當(dāng)你加入了對(duì)等組之后.你在這個(gè)對(duì)等組內(nèi)發(fā)布的信息就只有這個(gè)組的成員才能收到,所謂的成員資格服務(wù)^_^.(差不多這個(gè)意思吧.不完全對(duì).)
但是你不能建立你自己的應(yīng)用中所私有的組的話.那么別人通過搜索 * 匹配來得到你的組通告就可以加入你建立的對(duì)等組.如果在你告訴了我你自己的應(yīng)用中組的名字的話.我就可以自己寫一個(gè)應(yīng)用來加入你的組進(jìn)行任意的破壞.^_^.
那么不就很不安全了嗎?應(yīng)用的維護(hù)管理也太不方便了.
雖然我之前寫過哪個(gè)關(guān)于通過認(rèn)證加入對(duì)等組的文章,但是哪個(gè)就是不安全.
其實(shí)可以通過建立ModuleImplAdvertisement 來為你的對(duì)等組增加帳號(hào)密碼的認(rèn)證
代碼如下:
????????ModuleImplAdvertisement?allPurposePeerGroupImplAdv=null;
????????try?{
????????????allPurposePeerGroupImplAdv=rootPeerGroup.getAllPurposePeerGroupImplAdvertisement();
????????}?catch?(java.lang.Exception?e)?{
????????????System.exit(1);
????????}
????????ModuleImplAdvertisement?passwdMembershipPeerGroupModuleImplAdv=allPurposePeerGroupImplAdv;
????????ModuleImplAdvertisement?passwdMembershipServiceModuleImplAdv=null;
????????StdPeerGroupParamAdv?passwdMembershipPeerGroupParamAdv=null;
????????try?{
????????????passwdMembershipPeerGroupParamAdv?=
????????????????new?StdPeerGroupParamAdv(allPurposePeerGroupImplAdv.getParam());
????????}?catch?(net.jxta.exception.PeerGroupException?e)?{
????????????System.exit(1);
????????}
????????Hashtable?allPurposePeerGroupServicesHashtable?=?passwdMembershipPeerGroupParamAdv.getServices();
????????Enumeration?allPurposePeerGroupServicesEnumeration?=?allPurposePeerGroupServicesHashtable.keys();
????????boolean?membershipServiceFound=false;
????????while?((!membershipServiceFound)?&&?(allPurposePeerGroupServicesEnumeration.hasMoreElements()))?{
????????????Object?allPurposePeerGroupServiceID?=?allPurposePeerGroupServicesEnumeration.nextElement();
????????????if?(allPurposePeerGroupServiceID.equals(PeerGroup.membershipClassID))?{
????????????????ModuleImplAdvertisement?allPurposePeerGroupMemershipServiceModuleImplAdv=?(ModuleImplAdvertisement)?allPurposePeerGroupServicesHashtable.get(allPurposePeerGroupServiceID);
????????????????passwdMembershipServiceModuleImplAdv=this.createPasswdMembershipServiceModuleImplAdv(allPurposePeerGroupMemershipServiceModuleImplAdv);
????????????????allPurposePeerGroupServicesHashtable.remove(allPurposePeerGroupServiceID);
????????????????allPurposePeerGroupServicesHashtable.put(PeerGroup.membershipClassID,passwdMembershipServiceModuleImplAdv);
????????????????membershipServiceFound=true;
????????????????passwdMembershipPeerGroupModuleImplAdv.setParam((Element)?passwdMembershipPeerGroupParamAdv.getDocument(new?MimeMediaType("text/xml")));
????????????????if?(!passwdMembershipPeerGroupModuleImplAdv.getModuleSpecID().equals(PeerGroup.allPurposePeerGroupSpecID))?{
????????????????????passwdMembershipPeerGroupModuleImplAdv.setModuleSpecID(IDFactory.newModuleSpecID(passwdMembershipPeerGroupModuleImplAdv.getModuleSpecID().getBaseClass()));
????????????????}?else?{
????????????????????ID?passwdGrpModSpecID=?ID.nullID;
????????????????????try?{
????????????????????????passwdGrpModSpecID?=?IDFactory.fromURL(new?URL("urn","","jxta:uuid-"+"DeadBeefDeafBabaFeedBabe00000001"?+"04"?+"06"?)?);
????????????????????}?catch?(java.net.MalformedURLException?e)?{}
????????????????????catch?(java.net.UnknownServiceException?ee)?{}
????????????????????passwdMembershipPeerGroupModuleImplAdv.setModuleSpecID((ModuleSpecID)?passwdGrpModSpecID);
????????????????}?
????????????????membershipServiceFound=true;
????????????}?
????????}
????????return?passwdMembershipPeerGroupModuleImplAdv;
????}
????private??ModuleImplAdvertisement?createPasswdMembershipServiceModuleImplAdv(?ModuleImplAdvertisement?allPurposePeerGroupMemershipServiceModuleImplAdv)?{
????????ModuleImplAdvertisement?passwdMembershipServiceModuleImplAdv?=?(ModuleImplAdvertisement)?AdvertisementFactory.newAdvertisement(ModuleImplAdvertisement.getAdvertisementType());
????????passwdMembershipServiceModuleImplAdv.setModuleSpecID(PasswdMembershipService.passwordMembershipSpecID);
????????passwdMembershipServiceModuleImplAdv.setCode(PasswdMembershipService.class.getName());
????????passwdMembershipServiceModuleImplAdv.setDescription("?Module?Impl?Advertisement?for?the?PasswdMembership?Service");
????????passwdMembershipServiceModuleImplAdv.setCompat(allPurposePeerGroupMemershipServiceModuleImplAdv.getCompat());
????????passwdMembershipServiceModuleImplAdv.setUri(allPurposePeerGroupMemershipServiceModuleImplAdv.getUri());
????????passwdMembershipServiceModuleImplAdv.setProvider(allPurposePeerGroupMemershipServiceModuleImplAdv.getProvider());
????????return?passwdMembershipServiceModuleImplAdv;
????}
好了.之后你就可以利用這個(gè)ModuleImplAdvertisement 來建立你的應(yīng)用中專用的對(duì)等組了.
PS:關(guān)于如何讓JXTA在不同的網(wǎng)絡(luò)中進(jìn)行通訊的問題,雖然JXTA里面已經(jīng)說明了自己有這樣的能力可以做到.但是到底是如何實(shí)現(xiàn)呢? 下次再說 ^_^
轉(zhuǎn)載于:https://www.cnblogs.com/TtTiCk/archive/2006/08/30/490678.html
總結(jié)
以上是生活随笔為你收集整理的让你的JXTA应用更加安全.建立真正你自己的私有的组!的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 8-26日培训日记
- 下一篇: 如何写好一份工程师简历