我正在尝试使用 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.
我假设由于第 7 行中的定位器查找失败,为 print sle.nextElement() 语句打印了 null:
Locator locator = ServiceLocationManager.getLocator(new Locale("en"));
所以我的问题是有谁知道为什么 IP_MULTICAST_IF 的一个不好的论点会导致这个问题以及如何解决它?如果有人看到除了 IP_MULTICAST_IF 之外的其他问题,请随时指出。
附带说明一下,如果知道我在 Ubuntu 11.04 上使用 JavaSE-1.6、jslp-0.7.1 和 commons-loggin-1.1.1 库会有所帮助。