是否有使用mdnsjava的网络服务发现示例? 问题
我正在尝试开始Java客户机/服务器应用程序的网络服务发现——基本上,我只希望客户机在同一以太网段上查找服务器,而不进行配置。我想为将来的客户在其他平台上提供服务。可能只有NETCF和Android。这不应该是火箭手术 选择权 几个小时的浏览似乎表明mdnsjava是目前最好的选择。我在下面发布了一些我的研究,但以我目前的声誉,我只限于两个链接 我得到的例子编译,注册和浏览没有太多的悲伤。。。但它根本无法可靠地工作。浏览器返回255.255.254子网上的IP地址,在找到服务的情况下 得到更好的评论,但我完全没能让它运行。我发现的示例是不独立的代码片段,而Javadoc并不是真正的文档——它们只是带有未命名(但必须)参数的公共方法列表 自2009年以来,Avahi4j一直停留在v0.1。没有花时间在这上面 Bonjour显然需要非苹果平台上的系统库 Upnp,我承认对它一无所知,看起来需要大量的基础设施才能满足我的最低要求 问题:是否有使用mdnsjava的网络服务发现示例? 问题,java,mdns,jmdns,mdnsjava,Java,Mdns,Jmdns,Mdnsjava,我正在尝试开始Java客户机/服务器应用程序的网络服务发现——基本上,我只希望客户机在同一以太网段上查找服务器,而不进行配置。我想为将来的客户在其他平台上提供服务。可能只有NETCF和Android。这不应该是火箭手术 选择权 几个小时的浏览似乎表明mdnsjava是目前最好的选择。我在下面发布了一些我的研究,但以我目前的声誉,我只限于两个链接 我得到的例子编译,注册和浏览没有太多的悲伤。。。但它根本无法可靠地工作。浏览器返回255.255.254子网上的IP地址,在找到服务的情况下 得到更好的
是否存在使用mdnsjava注册服务的可编译工作示例?如果这是我在2015年的最佳行动方案,我准备调查另一个库。结果证明,最简单的答案是使用MulticastSocket推出自己的库,至少对于我的简单应用程序是如此 任何试图这样做的人都要注意:试图让客户机在.NETCF3.5中工作并没有多大乐趣。没有异步支持,超时不起作用,关于多播支持的文档(在CF中)也不存在。我最终在自己的线程中编写了一个同步客户端。它立即返回前两个服务器,然后等待其他服务器超过一分钟。残忍
import java.net.MulticastSocket;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
public class Main {
public static void main(String[] args) {
if( args.length == 0 ) runClient();
if(args[0].equals("s")) runServer();
else runClient();
}
static String mcastAddr = "239.255.100.100"; // Chosen at random from local network block at http://www.iana.org/assignments/multicast-addresses/multicast-addresses.xhtml
static int port = 4446;
public static void runServer() {
while (true) {
try {
MulticastSocket s = new MulticastSocket(port);
InetAddress group = InetAddress.getByName(mcastAddr);
s.joinGroup(group);
byte[] recData = new byte[100];
DatagramPacket receivePacket = new DatagramPacket(recData, recData.length);
s.receive(receivePacket);
String strrec = new String(recData,0,receivePacket.getLength());
print("server received: " + strrec);
print("from: " + receivePacket.getAddress().toString());
if(strrec.equals("Are you there?")) {
String msg = "Here I am";
byte[] msgData = msg.getBytes();
DatagramPacket msgPacket = new DatagramPacket(msgData, msgData.length, receivePacket.getAddress(), receivePacket.getPort());
s.send(msgPacket);
print("server sent: " + msg + "\n");
} else {
print("Didn't send; unrecognized message.");
}
} catch (Exception e) {
print(e.toString());
}
}
}
public static void runClient() {
try {
DatagramSocket s = new DatagramSocket();
String msg = "Are you there?"; // Magic string
byte[] msgData = msg.getBytes();
DatagramPacket datagramPacket = new DatagramPacket(msgData, msgData.length, InetAddress.getByName(mcastAddr), port);
s.send(datagramPacket);
print("client sent: " + msg);
byte[] recData = new byte[100];
DatagramPacket receivePacket = new DatagramPacket(recData, recData.length);
s.receive(receivePacket);
String strrec = new String(recData,0,receivePacket.getLength());
print("client received: " + strrec);
print("from " + receivePacket.getAddress().toString() + " : " + receivePacket.getPort());
System.exit(0);
} catch (Exception e) {
print(e.toString());
}
}
static void print(String s) { System.out.println(s); }
}
我得出了同样的结论。尝试了一组MDN库。使用JmDNS实现了一个解决方案,由于内存和线程耗尽问题,不得不将其拉入。最终,我们采用了一种简单的UDP广播解决方案。它足够简单,我可以完全理解它,老实说,我不知道我失去了什么功能。