4

我正在尝试使用 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 库会有所帮助。

4

1 回答 1

4

我刚刚遇到了同样的问题。为我解决的问题是

System.setProperty("java.net.preferIPv4Stack", "true")

在启动时,也可以通过将以下参数添加到 java cmd 行来完成。

-Djava.net.preferIPv4Stack=true 
于 2014-04-26T12:48:48.030 回答