我试图使用Java找到一个名为test的SLP服务,该服务在我的网络上运行,并创建到它的连接。我知道服务正在运行,并且可以使用命令"slptool findsrvs service:test"来查找它。该命令返回"service:test://192.168.1.4:12345,65535"。但是下面的代码:
import java.util.Locale;
import ch.ethz.iks.slp.*;
public class OpenConnection {
public static void main(String[] args) throws ServiceLocationException {
Locator locator = ServiceLocationManager.getLocator(new Locale("en"));
ServiceLocationEnumeration sle = locator.findServices(new ServiceType("service:test"), null, null);
System.out.println("Looking up ...");
System.out.println(sle.nextElement());
while (sle.hasMoreElements()) {
ServiceURL foundService = (ServiceURL) sle.nextElement();
System.out.println(foundService);
}
System.out.println("Finished.");
}
}
产生以下输出:
java.net.SocketException: bad argument for IP_MULTICAST_IF: address not bound to any interface
at java.net.PlainDatagramSocketImpl.socketSetOption(Native Method)
at java.net.AbstractPlainDatagramSocketImpl.setOption(AbstractPlainDatagramSocketImpl.java:299)
at java.net.MulticastSocket.setInterface(MulticastSocket.java:448)
at ch.ethz.iks.slp.impl.SLPCore.<clinit>(SLPCore.java:279)
at OpenConnection.main(OpenConnection.java:7)
Looking up ...
null
Finished.
我假设print sleep . nextelement()语句打印null,因为第7行定位器查找失败:
Locator locator = ServiceLocationManager.getLocator(new Locale("en"));
所以我的问题是,有没有人知道为什么IP_MULTICAST_IF的一个糟糕的参数会导致这种情况,以及如何修复它?如果有人发现IP_MULTICAST_IF之外的东西可能导致问题,请随时指出来。
如果它有助于知道我在Ubuntu 11.04上使用的是javascript -1.6, jslp-0.7.1和commons- login -1.1.1库。
我刚刚遇到了同样的问题。为我修复它的是做一个
System.setProperty("java.net.preferIPv4Stack", "true")
在启动时,也可以通过在Java CMD行中添加以下参数来完成。
-Djava.net.preferIPv4Stack=true