- 浏览: 194867 次
- 性别:
- 来自: 上海
-
文章分类
最新评论
-
sogo1986:
简直胡说八道
SessionFactoryUtils.getSession(getSessionFactory(), true); -
liuyinhuan:
请问多个Procedure之间能不能用同一个Cursor?怎么 ...
oracle存储过程 cursor使用 -
allengorr:
好人,真的,对于我们这样的初学者,太好了,谢谢!
Hibernate中Session的操作解释 -
deepsea0001:
netstat -n
查询端口使用的命令 -
kaixinwoo1:
:sdaf:
web.xml加载servlet
自己写的JXTA CMS例子
注意:下面两个例子要放在不同工程中。
分享端:
[java] view plaincopy
package com.yangsure.cms;
import java.io.File;
import java.util.logging.Level;
import java.util.logging.Logger;
import net.jxta.peergroup.*;
import net.jxta.share.*;
public class SimpleShare {
public SimpleShare() {
}
private PeerGroup netPeerGroup = null;
private CMS cms = null;
public static void main(String args[]) {
SimpleShare myShare = new SimpleShare();
myShare.startCMS();
}
public void startCMS() {
try {
Logger.getLogger("net.jxta").setLevel(Level.SEVERE);
System.out.println("start CMS...... ");
netPeerGroup = PeerGroupFactory.newNetPeerGroup();
cms = new CMS();
cms.init(netPeerGroup, null, netPeerGroup
.getPeerGroupAdvertisement());
String homedir = "SimpleShare";
if (cms.startApp(new File(homedir)) == -1) {
System.out.println("CMS initialization failed ");
System.exit(-1);
}
releaseShareFiles(new File("./src/java.txt"));
while (true) {
Thread.sleep(5000);
}
} catch (Exception e) {
System.out.println(e.getMessage());
System.exit(-1);
}
}
public void releaseShareFiles(File f) {
try {
cms.getContentManager().share(f);
System.out.println("share files ");
} catch (Exception e) {
System.out.println(e.getMessage());
}
}
}
搜索下载端:
[java] view plaincopy
package com.yangsure.cms;
import java.io.File;
import java.util.logging.Level;
import java.util.logging.Logger;
import net.jxta.peergroup.*;
import net.jxta.share.*;
import net.jxta.share.client.*;
public class SimpleSearch {
private PeerGroup netPeerGroup = null;
private ListContentRequest request = null;
private String searchString = null;
public SimpleSearch(String subStr) {
searchString = subStr;
}
public static void main(String args[]) {
SimpleSearch mySearch = new SimpleSearch("java.txt");
mySearch.run();
}
public void run() {
try {
Logger.getLogger("net.jxta").setLevel(Level.SEVERE);
netPeerGroup = PeerGroupFactory.newNetPeerGroup();
while (true) {
request = new MyListRequest(netPeerGroup, searchString);
request.activateRequest();
System.out.println("have result");
Thread.sleep(5000);
request.cancel();
}
} catch (Exception e) {
System.out.println(e.getMessage());
System.exit(-1);
}
}
class MyGetRequest extends GetContentRequest {
public MyGetRequest(PeerGroup group, ContentAdvertisement adv,
File inFile) {
super(group, adv, inFile);
}
public MyGetRequest(PeerGroup group, ContentAdvertisement[] adv,
File inFile) {
super(group, adv, inFile);
}
}
class MyListRequest extends CachedListContentRequest {
private PeerGroup group;
public MyListRequest(PeerGroup group, String subString) {
super(group, subString);
this.group = group;
}
public void notifyMoreResults() {
System.out.println("come ");
ContentAdvertisement[] res = getResults();
for (int i = 0; i < res.length; i++) {
System.out.println(res[i].getName());
MyGetRequest m = new MyGetRequest(group, res[i], new File(
"c:/java.txt"));
m.run();
}
}
}
}
下需要下载jxta依赖的包以及jxtacms.jar
JXTA的一个例子
这是一个简单的应用JXTA的客户/服务器结构的例子,服务器端创建监听线程,客户端主动连接一次。所有代码非常简洁的说明了JXTA的C/S应用的设计框架,原例子是在http://www.jxta.org/Tutorials.html,我在本机和局域网内已调试通过,并加了注释,有兴趣的朋友看看吧。
需要引用的jar包有三个:jxta.jar,log4j.jar,bcprov-jdk14.jar
服务器端
package com.solo.server;
import java.io.*;
import net.jxta.discovery.*;
import net.jxta.document.*;
import net.jxta.endpoint.*;
import net.jxta.exception.*;
import net.jxta.id.*;
import net.jxta.peergroup.*;
import net.jxta.pipe.*;
import net.jxta.platform.*;
import net.jxta.protocol.*;
public class SoloServer {
static PeerGroup group = null;
static PeerGroupAdvertisement groupAdvertisement = null;
private DiscoveryService discovery;
private PipeService pipes;
private InputPipe myPipe; // 输入管道,从客户端来的
private Message msg; // 收到的消息
private ID gid;
public static void main(String[] args) {
SoloServer myServer = new SoloServer();
System.out.println("Starting service peer...");
System.out.println(System.getProperty("user.dir"));
myServer.startJxta();
System.out.println("Good Bye ....");
System.exit(0);
}
private void startJxta() {
try {
// 开始,要使用默认的JXTA组
group = PeerGroupFactory.newNetPeerGroup();
}
catch (PeerGroupException ex) {
System.out.println("fatal error : group creation failure");
ex.printStackTrace();
System.exit(1);
}
// 得到默认组的通告
groupAdvertisement = group.getPeerGroupAdvertisement();
// 获取该通告的发现服务
System.out.println("Getting DiscoveryService...");
discovery = group.getDiscoveryService();
// 获取该通告的管道服务
System.out.println("Getting PipeService...");
pipes = group.getPipeService();
startServer();
}
private void startServer() {
System.out.println("Start the Server daemon...");
// 读该组的ID
gid = group.getPeerGroupID();
try {
// 创建一个模块化的简单的通告,此通告仅仅用来表示该服务的存在。
// 如果端点要访问该服务,还得创建一个指定的通告,来关联服务。
ModuleClassAdvertisement mcadv = (ModuleClassAdvertisement)
AdvertisementFactory.newAdvertisement(ModuleClassAdvertisement.
getAdvertisementType());
mcadv.setName("JXTAMOD:JXTA-SOLO-XDS-CN");
mcadv.setDescription("SOLO SERVER FOR SOLO-CN WITH JXTA FRAMEWORK.");
ModuleClassID mcID = IDFactory.newModuleClassID();
mcadv.setModuleClassID(mcID);
discovery.publish(mcadv);
discovery.remotePublish(mcadv);
// 创建一个指定的通告,使得端点可以与服务相连。
// 该通告包含端点连接服务所需要的所有信息,
// 例如它包含一个端点用来与服务关联的输入管道数据
ModuleSpecAdvertisement mdadv = (ModuleSpecAdvertisement)
AdvertisementFactory.newAdvertisement(ModuleSpecAdvertisement.
getAdvertisementType());
// 填充相关的信息
mdadv.setName("JXTASPEC:JXTA-SOLO-XDS-CN");
mdadv.setVersion("VERISON 1.0");
mdadv.setCreator("solo.com");
mdadv.setModuleSpecID(IDFactory.newModuleSpecID(mcID));
mdadv.setSpecURI("http://www.solo_xds.cn");
// 创建输入管道,端点必须使用同样的管道才能与服务通话,
// 当端点发现服务通告时,提取此管道数据来创建它的输出管道,
// 我们采用从文件中读取该管道信息的原因是为了保证每次创建的都是相同的管道。
System.out.println("Reading in PipeService.adv....");
PipeAdvertisement pipeadv = null;
try {
FileInputStream is = new FileInputStream("pipeserver.adv");
XMLDocument document = (XMLDocument) StructuredDocumentFactory.
newStructuredDocument(MimeMediaType.XMLUTF8, is);
pipeadv = (PipeAdvertisement)
AdvertisementFactory.newAdvertisement(
document);
is.close();
}
catch (Exception e) {
System.out.println("failed to read/parse pipe advertisement");
e.printStackTrace();
System.exit( -1);
}
// 将此管道的通告保存在指定的服务通告中,
// 每次端点与服务联系时都可得到此通告。
mdadv.setPipeAdvertisement(pipeadv);
// 显示一下服务通告
StructuredTextDocument doc = (StructuredTextDocument)
mdadv.getDocument(MimeMediaType.XMLUTF8);
StringWriter out = new StringWriter();
doc.sendToWriter(out);
System.out.println(out.toString());
out.close();
// 好了,通告已经建立,发布到本地缓存和默认组的缓存中。
discovery.publish(mdadv);
discovery.remotePublish(mdadv);
//开始服务了,准备好输入管道吧。
myPipe = pipes.createInputPipe(pipeadv);
}
catch (Exception ex) {
ex.printStackTrace();
System.out.println("Server: Error publishing the module");
}
// listen死循环,不能停止
while (true) {
System.out.println("Waiting for client messages to arrive...");
try {
// listen pipe
msg = myPipe.waitForMessage();
}
catch (Exception e) {
myPipe.close();
System.out.println("Server: Error listening for message");
return;
}
String ip = null;
// 读取端点传来的信息
try {
Message.ElementIterator en = msg.getMessageElements();
if (!en.hasNext()) {
return;
}
MessageElement msgElement = msg.getMessageElement(null, "DataTag");
if (msgElement.toString() != null) {
ip = msgElement.toString();
}
if (ip != null) {
// 显示吧
System.out.println("Server: receive message: " + ip);
}
else {
System.out.println("Server: error could not find the tag");
}
}
catch (Exception ex) {
System.out.println("Server: error receiving message");
}
}
}
}
客户端
package com.solo.client;
import java.io.*;
import java.util.*;
import net.jxta.discovery.*;
import net.jxta.document.*;
import net.jxta.endpoint.*;
import net.jxta.exception.*;
import net.jxta.peergroup.*;
import net.jxta.pipe.*;
import net.jxta.protocol.*;
public class SoloClient {
static PeerGroup netPeerGroup = null;
static PeerGroupAdvertisement groupAdvertisement = null;
private DiscoveryService discovery;
private PipeService pipes;
private OutputPipe myPipe; // 输出管道,到服务的
private Message msg;
public SoloClient() {
}
public static void main(String[] args) {
SoloClient myClient = new SoloClient();
System.out.println("Starting Client peer ....");
myClient.startJxta();
System.out.println("Good Bye ....");
System.exit(0);
}
/**
* startJxta
*/
private void startJxta() {
try {
// 创建默认的JXTA组。
netPeerGroup = PeerGroupFactory.newNetPeerGroup();
}
catch (PeerGroupException e) {
System.out.println("fatal error : group creation failure");
e.printStackTrace();
System.exit(1);
}
// 获取该组通告
groupAdvertisement = netPeerGroup.getPeerGroupAdvertisement();
// 获取该组发现服务
System.out.println("Getting DiscoveryService");
discovery = netPeerGroup.getDiscoveryService();
// 获取该组管道服务
System.out.println("Getting PipeService");
pipes = netPeerGroup.getPipeService();
startClient();
}
private void startClient() {
System.out.println("Start the Client");
// 找到服务
System.out.println("searching for the JXTA-SOLO-XDS-CN Service advertisement");
Enumeration en = null;
while (true) {
try {
// 在本地的缓存中查找服务(JXTA-SOLO-XDS-CN)
en = discovery.getLocalAdvertisements(DiscoveryService.ADV
, "Name"
, "JXTASPEC:JXTA-SOLO-XDS-CN");
// 找到就好
if ( (en != null) && en.hasMoreElements()) {
break;
}
// 本地没有,只好根据服务名称远程搜索
discovery.getRemoteAdvertisements(null
, DiscoveryService.ADV
, "Name"
, "JXTASPEC:JXTA-SOLO-XDS-CN", 1, null);
// 发现过程是异步的,我们不知道需要多长时间
try {
Thread.sleep(2000);
}
catch (Exception e) {}
}
catch (IOException e) {
// 啥也没找到,继续
}
//显示点吧
System.out.print(".");
}
System.out.println("we found the service advertisement");
// 找到以后,得到特殊服务的通告
ModuleSpecAdvertisement mdsadv = (ModuleSpecAdvertisement) en.nextElement();
try {
// 显示一下通告而已
StructuredTextDocument doc = (StructuredTextDocument)
mdsadv.getDocument(MimeMediaType.TEXT_DEFAULTENCODING);
StringWriter out = new StringWriter();
doc.sendToWriter(out);
System.out.println(out.toString());
out.close();
// 根据获取的通告,获取管道
PipeAdvertisement pipeadv = mdsadv.getPipeAdvertisement();
// 用上面的通道,通知服务创建输出通道了,试着创建3次。
for (int i = 0; i < 3; i++) {
myPipe = pipes.createOutputPipe(pipeadv, 10000);
}
// 要说的话
String data = "我靠,成功啦!!!";
// 组织成消息
msg = new Message();
StringMessageElement sme = new StringMessageElement("DataTag", data, null);
msg.addMessageElement(null, sme);
// 通过管道发送吧
myPipe.send(msg);
System.out.println("message \"" + data + "\" sent to the Server");
}
catch (Exception ex) {
ex.printStackTrace();
System.out.println("Client: Error sending message to the service");
}
}
}
==========================================
在服务器端的根目录下还需要一个叫作pipeserver.adv的管道通告文件,这个文件的作用是使得每次服务启动时创建的都是同一个管道服务。
<?xml version="1.0"?>
<!DOCTYPE jxta:PipeAdvertisement>
<jxta:PipeAdvertisement xmlns:jxta="http://jxta.org">
&<60;&<60;<Id>
&<60;&<60;&<60;&<60;urn:jxta:uuid-9CCCDF5AD8154D3D87A391210404E59BE4B888209A2241A4A162A10916074A9504
&<60;&<60;</Id>
&<60;&<60;<Type>JxtaUnicast</Type>
&<60;&<60;<Name>JXTA-SOLO-XDS-CN</Name>
</jxta:PipeAdvertisement>
第一次启动服务器和客户端时需要输入节点名和密码,随便输入就可以了。
分享端:
[java] view plaincopy
package com.yangsure.cms;
import java.io.File;
import java.util.logging.Level;
import java.util.logging.Logger;
import net.jxta.peergroup.*;
import net.jxta.share.*;
public class SimpleShare {
public SimpleShare() {
}
private PeerGroup netPeerGroup = null;
private CMS cms = null;
public static void main(String args[]) {
SimpleShare myShare = new SimpleShare();
myShare.startCMS();
}
public void startCMS() {
try {
Logger.getLogger("net.jxta").setLevel(Level.SEVERE);
System.out.println("start CMS...... ");
netPeerGroup = PeerGroupFactory.newNetPeerGroup();
cms = new CMS();
cms.init(netPeerGroup, null, netPeerGroup
.getPeerGroupAdvertisement());
String homedir = "SimpleShare";
if (cms.startApp(new File(homedir)) == -1) {
System.out.println("CMS initialization failed ");
System.exit(-1);
}
releaseShareFiles(new File("./src/java.txt"));
while (true) {
Thread.sleep(5000);
}
} catch (Exception e) {
System.out.println(e.getMessage());
System.exit(-1);
}
}
public void releaseShareFiles(File f) {
try {
cms.getContentManager().share(f);
System.out.println("share files ");
} catch (Exception e) {
System.out.println(e.getMessage());
}
}
}
搜索下载端:
[java] view plaincopy
package com.yangsure.cms;
import java.io.File;
import java.util.logging.Level;
import java.util.logging.Logger;
import net.jxta.peergroup.*;
import net.jxta.share.*;
import net.jxta.share.client.*;
public class SimpleSearch {
private PeerGroup netPeerGroup = null;
private ListContentRequest request = null;
private String searchString = null;
public SimpleSearch(String subStr) {
searchString = subStr;
}
public static void main(String args[]) {
SimpleSearch mySearch = new SimpleSearch("java.txt");
mySearch.run();
}
public void run() {
try {
Logger.getLogger("net.jxta").setLevel(Level.SEVERE);
netPeerGroup = PeerGroupFactory.newNetPeerGroup();
while (true) {
request = new MyListRequest(netPeerGroup, searchString);
request.activateRequest();
System.out.println("have result");
Thread.sleep(5000);
request.cancel();
}
} catch (Exception e) {
System.out.println(e.getMessage());
System.exit(-1);
}
}
class MyGetRequest extends GetContentRequest {
public MyGetRequest(PeerGroup group, ContentAdvertisement adv,
File inFile) {
super(group, adv, inFile);
}
public MyGetRequest(PeerGroup group, ContentAdvertisement[] adv,
File inFile) {
super(group, adv, inFile);
}
}
class MyListRequest extends CachedListContentRequest {
private PeerGroup group;
public MyListRequest(PeerGroup group, String subString) {
super(group, subString);
this.group = group;
}
public void notifyMoreResults() {
System.out.println("come ");
ContentAdvertisement[] res = getResults();
for (int i = 0; i < res.length; i++) {
System.out.println(res[i].getName());
MyGetRequest m = new MyGetRequest(group, res[i], new File(
"c:/java.txt"));
m.run();
}
}
}
}
下需要下载jxta依赖的包以及jxtacms.jar
JXTA的一个例子
这是一个简单的应用JXTA的客户/服务器结构的例子,服务器端创建监听线程,客户端主动连接一次。所有代码非常简洁的说明了JXTA的C/S应用的设计框架,原例子是在http://www.jxta.org/Tutorials.html,我在本机和局域网内已调试通过,并加了注释,有兴趣的朋友看看吧。
需要引用的jar包有三个:jxta.jar,log4j.jar,bcprov-jdk14.jar
服务器端
package com.solo.server;
import java.io.*;
import net.jxta.discovery.*;
import net.jxta.document.*;
import net.jxta.endpoint.*;
import net.jxta.exception.*;
import net.jxta.id.*;
import net.jxta.peergroup.*;
import net.jxta.pipe.*;
import net.jxta.platform.*;
import net.jxta.protocol.*;
public class SoloServer {
static PeerGroup group = null;
static PeerGroupAdvertisement groupAdvertisement = null;
private DiscoveryService discovery;
private PipeService pipes;
private InputPipe myPipe; // 输入管道,从客户端来的
private Message msg; // 收到的消息
private ID gid;
public static void main(String[] args) {
SoloServer myServer = new SoloServer();
System.out.println("Starting service peer...");
System.out.println(System.getProperty("user.dir"));
myServer.startJxta();
System.out.println("Good Bye ....");
System.exit(0);
}
private void startJxta() {
try {
// 开始,要使用默认的JXTA组
group = PeerGroupFactory.newNetPeerGroup();
}
catch (PeerGroupException ex) {
System.out.println("fatal error : group creation failure");
ex.printStackTrace();
System.exit(1);
}
// 得到默认组的通告
groupAdvertisement = group.getPeerGroupAdvertisement();
// 获取该通告的发现服务
System.out.println("Getting DiscoveryService...");
discovery = group.getDiscoveryService();
// 获取该通告的管道服务
System.out.println("Getting PipeService...");
pipes = group.getPipeService();
startServer();
}
private void startServer() {
System.out.println("Start the Server daemon...");
// 读该组的ID
gid = group.getPeerGroupID();
try {
// 创建一个模块化的简单的通告,此通告仅仅用来表示该服务的存在。
// 如果端点要访问该服务,还得创建一个指定的通告,来关联服务。
ModuleClassAdvertisement mcadv = (ModuleClassAdvertisement)
AdvertisementFactory.newAdvertisement(ModuleClassAdvertisement.
getAdvertisementType());
mcadv.setName("JXTAMOD:JXTA-SOLO-XDS-CN");
mcadv.setDescription("SOLO SERVER FOR SOLO-CN WITH JXTA FRAMEWORK.");
ModuleClassID mcID = IDFactory.newModuleClassID();
mcadv.setModuleClassID(mcID);
discovery.publish(mcadv);
discovery.remotePublish(mcadv);
// 创建一个指定的通告,使得端点可以与服务相连。
// 该通告包含端点连接服务所需要的所有信息,
// 例如它包含一个端点用来与服务关联的输入管道数据
ModuleSpecAdvertisement mdadv = (ModuleSpecAdvertisement)
AdvertisementFactory.newAdvertisement(ModuleSpecAdvertisement.
getAdvertisementType());
// 填充相关的信息
mdadv.setName("JXTASPEC:JXTA-SOLO-XDS-CN");
mdadv.setVersion("VERISON 1.0");
mdadv.setCreator("solo.com");
mdadv.setModuleSpecID(IDFactory.newModuleSpecID(mcID));
mdadv.setSpecURI("http://www.solo_xds.cn");
// 创建输入管道,端点必须使用同样的管道才能与服务通话,
// 当端点发现服务通告时,提取此管道数据来创建它的输出管道,
// 我们采用从文件中读取该管道信息的原因是为了保证每次创建的都是相同的管道。
System.out.println("Reading in PipeService.adv....");
PipeAdvertisement pipeadv = null;
try {
FileInputStream is = new FileInputStream("pipeserver.adv");
XMLDocument document = (XMLDocument) StructuredDocumentFactory.
newStructuredDocument(MimeMediaType.XMLUTF8, is);
pipeadv = (PipeAdvertisement)
AdvertisementFactory.newAdvertisement(
document);
is.close();
}
catch (Exception e) {
System.out.println("failed to read/parse pipe advertisement");
e.printStackTrace();
System.exit( -1);
}
// 将此管道的通告保存在指定的服务通告中,
// 每次端点与服务联系时都可得到此通告。
mdadv.setPipeAdvertisement(pipeadv);
// 显示一下服务通告
StructuredTextDocument doc = (StructuredTextDocument)
mdadv.getDocument(MimeMediaType.XMLUTF8);
StringWriter out = new StringWriter();
doc.sendToWriter(out);
System.out.println(out.toString());
out.close();
// 好了,通告已经建立,发布到本地缓存和默认组的缓存中。
discovery.publish(mdadv);
discovery.remotePublish(mdadv);
//开始服务了,准备好输入管道吧。
myPipe = pipes.createInputPipe(pipeadv);
}
catch (Exception ex) {
ex.printStackTrace();
System.out.println("Server: Error publishing the module");
}
// listen死循环,不能停止
while (true) {
System.out.println("Waiting for client messages to arrive...");
try {
// listen pipe
msg = myPipe.waitForMessage();
}
catch (Exception e) {
myPipe.close();
System.out.println("Server: Error listening for message");
return;
}
String ip = null;
// 读取端点传来的信息
try {
Message.ElementIterator en = msg.getMessageElements();
if (!en.hasNext()) {
return;
}
MessageElement msgElement = msg.getMessageElement(null, "DataTag");
if (msgElement.toString() != null) {
ip = msgElement.toString();
}
if (ip != null) {
// 显示吧
System.out.println("Server: receive message: " + ip);
}
else {
System.out.println("Server: error could not find the tag");
}
}
catch (Exception ex) {
System.out.println("Server: error receiving message");
}
}
}
}
客户端
package com.solo.client;
import java.io.*;
import java.util.*;
import net.jxta.discovery.*;
import net.jxta.document.*;
import net.jxta.endpoint.*;
import net.jxta.exception.*;
import net.jxta.peergroup.*;
import net.jxta.pipe.*;
import net.jxta.protocol.*;
public class SoloClient {
static PeerGroup netPeerGroup = null;
static PeerGroupAdvertisement groupAdvertisement = null;
private DiscoveryService discovery;
private PipeService pipes;
private OutputPipe myPipe; // 输出管道,到服务的
private Message msg;
public SoloClient() {
}
public static void main(String[] args) {
SoloClient myClient = new SoloClient();
System.out.println("Starting Client peer ....");
myClient.startJxta();
System.out.println("Good Bye ....");
System.exit(0);
}
/**
* startJxta
*/
private void startJxta() {
try {
// 创建默认的JXTA组。
netPeerGroup = PeerGroupFactory.newNetPeerGroup();
}
catch (PeerGroupException e) {
System.out.println("fatal error : group creation failure");
e.printStackTrace();
System.exit(1);
}
// 获取该组通告
groupAdvertisement = netPeerGroup.getPeerGroupAdvertisement();
// 获取该组发现服务
System.out.println("Getting DiscoveryService");
discovery = netPeerGroup.getDiscoveryService();
// 获取该组管道服务
System.out.println("Getting PipeService");
pipes = netPeerGroup.getPipeService();
startClient();
}
private void startClient() {
System.out.println("Start the Client");
// 找到服务
System.out.println("searching for the JXTA-SOLO-XDS-CN Service advertisement");
Enumeration en = null;
while (true) {
try {
// 在本地的缓存中查找服务(JXTA-SOLO-XDS-CN)
en = discovery.getLocalAdvertisements(DiscoveryService.ADV
, "Name"
, "JXTASPEC:JXTA-SOLO-XDS-CN");
// 找到就好
if ( (en != null) && en.hasMoreElements()) {
break;
}
// 本地没有,只好根据服务名称远程搜索
discovery.getRemoteAdvertisements(null
, DiscoveryService.ADV
, "Name"
, "JXTASPEC:JXTA-SOLO-XDS-CN", 1, null);
// 发现过程是异步的,我们不知道需要多长时间
try {
Thread.sleep(2000);
}
catch (Exception e) {}
}
catch (IOException e) {
// 啥也没找到,继续
}
//显示点吧
System.out.print(".");
}
System.out.println("we found the service advertisement");
// 找到以后,得到特殊服务的通告
ModuleSpecAdvertisement mdsadv = (ModuleSpecAdvertisement) en.nextElement();
try {
// 显示一下通告而已
StructuredTextDocument doc = (StructuredTextDocument)
mdsadv.getDocument(MimeMediaType.TEXT_DEFAULTENCODING);
StringWriter out = new StringWriter();
doc.sendToWriter(out);
System.out.println(out.toString());
out.close();
// 根据获取的通告,获取管道
PipeAdvertisement pipeadv = mdsadv.getPipeAdvertisement();
// 用上面的通道,通知服务创建输出通道了,试着创建3次。
for (int i = 0; i < 3; i++) {
myPipe = pipes.createOutputPipe(pipeadv, 10000);
}
// 要说的话
String data = "我靠,成功啦!!!";
// 组织成消息
msg = new Message();
StringMessageElement sme = new StringMessageElement("DataTag", data, null);
msg.addMessageElement(null, sme);
// 通过管道发送吧
myPipe.send(msg);
System.out.println("message \"" + data + "\" sent to the Server");
}
catch (Exception ex) {
ex.printStackTrace();
System.out.println("Client: Error sending message to the service");
}
}
}
==========================================
在服务器端的根目录下还需要一个叫作pipeserver.adv的管道通告文件,这个文件的作用是使得每次服务启动时创建的都是同一个管道服务。
<?xml version="1.0"?>
<!DOCTYPE jxta:PipeAdvertisement>
<jxta:PipeAdvertisement xmlns:jxta="http://jxta.org">
&<60;&<60;<Id>
&<60;&<60;&<60;&<60;urn:jxta:uuid-9CCCDF5AD8154D3D87A391210404E59BE4B888209A2241A4A162A10916074A9504
&<60;&<60;</Id>
&<60;&<60;<Type>JxtaUnicast</Type>
&<60;&<60;<Name>JXTA-SOLO-XDS-CN</Name>
</jxta:PipeAdvertisement>
第一次启动服务器和客户端时需要输入节点名和密码,随便输入就可以了。
相关推荐
在本项目中,使用JXTA CMS开发的文件共享系统应具备搜索、下载和共享文件的基本功能,用户界面直观,易于操作。 5. **项目要求** - 项目要求实现P2P网络中的搜索功能,允许用户查找网络上的特定文件。 - 下载功能...
DeepSeek与AI幻觉-清华大学团队制作 一、什么是AI幻觉 (定义与基础概念) 二、DeepSeek为什么会产生幻觉 (聚焦特定AI模型的幻觉成因分析) 三、AI幻觉评测 (评估AI幻觉的频率、类型与影响的方法) 四、如何减缓AI幻觉 (解决方案与技术优化方向) 五、AI幻觉的创造力价值 (探讨幻觉在创新场景中的潜在益处,如艺术生成、灵感激发等)
协同过滤算法商品推荐系统(源码+数据库+论文+ppt)java开发springboot框架javaweb,可做计算机毕业设计或课程设计 【功能需求】 前台用户可以实现注册登录、商品浏览,在线客服,加入购物车,加入收藏,下单购买,个人信息管理,收货信息管理,收藏管理,评论功能。 后台管理员可以进行用户管理、商品分类管理、商品信息管理、订单评价管理、系统管理、订单管理。 【环境需要】 1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。 2.IDE环境:IDEA,Eclipse,Myeclipse都可以。 3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可 4.数据库:MySql 5.7/8.0等版本均可; 【购买须知】 本源码项目经过严格的调试,项目已确保无误,可直接用于课程实训或毕业设计提交。里面都有配套的运行环境软件,讲解视频,部署视频教程,一应俱全,可以自己按照教程导入运行。附有论文参考,使学习者能够快速掌握系统设计和实现的核心技术。
MES系统数字化工厂解决方案.pptx
MUI调用照片以及裁剪和图库照片上传到服务器
GPT付费体验系统最新版系统是一款基于ThinkPHP框架开发的AI问答小程序, 是基于国外很火的ChatGPT进行开发的Ai智能问答小程序。这是一种基于人工智能技术的问答系统, 可以实现智能回答用户提出的问题。相比传统的问答系统,ChatGPT可以更加准确地理解用户的意图, 提供更加精准的答案。同时系统采用了最新的GPT3.5接口与GPT4模型,同时还支持型,文心一言,腾讯混元, 讯飞星火,通义千问,DeepSeeK,智普等等国内各种大模型,可以更好地适应不同的应用场景,支持站点无限多开, 可以说ChatGPT付费创作系统目前国内相对体验比较好的一款的ChatGPT及多接口软件系统。 新增接入DeepSeek-R1、DeepSeek-V3(Ollama自部署和第三方均支持)、高级通道增加DeepSeek、 支持AI接口输出的reasoning_content字段(新的推理输出格式)、更新模型库、修复导出Excel的bug等功能, 优化了云灵Midjourney接口,出图更快更稳定。小程序端变化不大该系统版本测试下来比较完美, 老版本升级时数据库结构同步下,同时把原来
内容概要:本文档详细介绍了一款基于Java技术的美食点餐管理平台的设计与实现。该平台旨在优化传统餐饮行业的服务流程,通过智能化的点餐系统、高效的订单处理、智能库存管理和数据分析等功能,为用户提供便捷高效的点餐体验,并提升餐厅管理效率和服务质量。系统涵盖了前端设计、后端开发、数据库设计等方面,采用了成熟的Java技术和现代Web开发框架,如Spring Boot、Vue.js或React,确保系统的高效性和稳定性。此外,文档还包括详细的用户界面设计、模块实现以及系统部署指南,帮助开发者理解和搭建该平台。 适合人群:具备一定的Java编程基础和技术经验的研发人员、IT从业者以及有意开发类似系统的企业和个人。 使用场景及目标:①为餐厅提供一个集点餐、订单处理、库存管理于一体的高效平台;②优化传统餐饮服务流程,提升客户服务体验;③利用大数据分析辅助决策,助力餐饮企业精细化运营;④通过集成多种支付方式和其他外部系统,满足多样化的商业需求。 其他说明:本项目不仅提供了完整的技术方案和支持文档,还针对实际应用场景提出了多个扩展方向和技术优化思路,旨在引导用户不断迭代和完善该平台的功能和性能。
相场模拟与激光制造技术:选择性激光烧结、激光融覆中的凝固与枝晶生长研究,相场模拟与激光制造技术:选择性激光烧结、激光融覆及凝固过程中的枝晶生长研究,相场模拟 选择性激光烧结 激光融覆 凝固 枝晶生长 ,相场模拟; 选择性激光烧结; 激光融覆; 凝固; 枝晶生长,相场模拟与激光工艺:枝晶生长的凝固过程研究
项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行;功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用
关于加强新能源汽车安全管理涉及的法规标准分析.pptx
项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行,功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用
项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行;功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用
UI+svg格式
关于乘用车燃料消耗量评价方法及指标强制性国家标准的分析.pptx
1、文件内容:openjpeg-1.5.1-18.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/openjpeg-1.5.1-18.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、更多资源/技术支持:公众号禅静编程坊
FPGA Verilog实现BT656与1120视频协议组帧解帧代码详解:含文档介绍与仿真验证,FPGA Verilog实现BT656与1120视频协议组帧解帧代码详解:含文档介绍与仿真验证,fpga verilog实现视频协议bt656和1120组帧解帧代码 有文档介绍协议,有mod仿真,matlab代码仿真 ,FPGA; Verilog; BT656协议; 1120组帧解帧代码; 文档介绍; Mod仿真; Matlab代码仿真,FPGA Verilog:实现BT656与1120组帧解帧代码的仿真与文档化研究
基于 RAG 与大模型技术的医疗问答系统,利用 DiseaseKG 数据集与 Neo4j 构 建知识图谱,结合 BERT 的命名实体识别和 34b 大模型的意图识别,通过精确的知识检索和问答生成, 提升系统在医疗咨询中的性能,解决大模型在医疗领域应用的可靠性问题。.zip项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行,功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用
项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行;功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用
抖音视频带货:行业趋势与营销策略.pptx
西门子动态密码程序:学习随机码生成与指针存储数据,Smartline触摸屏操作指南及编程视频教程,西门子动态密码程序:学习随机码生成与存储数据的智能之旅(视频讲解),200smart动态密码程序,触摸屏是smartline,西门子动态密码程序,,随机码的产生,指针用法存储数据,非常适合学习,而且是自己程序,还专门录制了一段视频来讲解编程的思路和画面的操作步骤。 ,200smart动态密码程序; touchscreen: smartline; 西门子动态密码程序; 随机码生成; 指针用法存储数据; 自学编程; 程序录制视频讲解。,西门子动态密码程序:触摸屏Smartline随机码生成与指针存储技术解析