Java-функция SLP, вызывающая исключение SocketException из-за IP_MULTICAST_IF - PullRequest
3 голосов
/ 28 июля 2011

Я пытаюсь использовать Java, чтобы найти службу SLP с именем test, которая работает в моей сети, и создать соединение с ней.Я знаю, что служба запущена и может использовать команду «slptool findrvs 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 sle.nextElement () выводится ноль из-за сбояищите локатор в строке 7:

Locator locator = ServiceLocationManager.getLocator(new Locale("en"));

Так что мой вопрос: кто-нибудь знает, почему плохой аргумент для IP_MULTICAST_IF может вызвать это и как это исправить?И если кто-то видит что-то, что может вызывать проблему, отличную от IP_MULTICAST_IF, пожалуйста, не стесняйтесь указывать на это.

На заметку, если это помогает узнать, что я использую JavaSE-1.6, jslp-0.7.1и библиотеки commons-loggin-1.1.1 в Ubuntu 11.04.

1 Ответ

3 голосов
/ 26 апреля 2014

Я просто столкнулся с той же проблемой. Что исправило это для меня делать

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

при запуске, что также можно сделать, добавив следующий аргумент в строку java cmd.

-Djava.net.preferIPv4Stack=true 
...