6

私は非常に単純な問題だと思ったことがあります。

私はJmDNSを使用してサービスをブロードキャストしようとしていますが、アプリが一時停止したときにサービスを登録解除し、アプリを再開してサービスを再登録したいと考えています。

ただし、これを行うと問題が発生します。コードは以下のとおりです。

//I use jmdns.create again before these lines which I don't know if i should?

mServiceInfo = ServiceInfo.create(registeredServiceName, registeredServiceType, registeredServicePort,"Hello");

try {       

     jmdnsNetworkDiscoveryManager.registerService(mServiceInfo);
    } 
catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
        Log.i(TAG, "Service Registration Error");
     }

これを試してみると、混乱する次のエラーログが表示されます。

07-29 10:38:13.099: W/DNSStateTask(28769): java.lang.StringIndexOutOfBoundsException: length=37; regionStart=0; regionLength=-1
07-29 10:38:13.099: W/DNSStateTask(28769):  at java.lang.String.startEndAndLength(String.java:593)

07-29 10:38:13.099: W/DNSStateTask(28769):  at java.lang.String.substring(String.java:1474)

07-29 10:38:13.099: W/DNSStateTask(28769):  at javax.jmdns.impl.ServiceInfoImpl.decodeQualifiedNameMapForType(ServiceInfoImpl.java:292)

07-29 10:38:13.099: W/DNSStateTask(28769):  at javax.jmdns.impl.DNSEntry.<init>(DNSEntry.java:47)

07-29 10:38:13.099: W/DNSStateTask(28769):  at javax.jmdns.impl.DNSQuestion.<init>(DNSQuestion.java:220)

07-29 10:38:13.099: W/DNSStateTask(28769):  at javax.jmdns.impl.DNSQuestion$AllRecords.<init>(DNSQuestion.java:184)

07-29 10:38:13.099: W/DNSStateTask(28769):  at javax.jmdns.impl.DNSQuestion.newQuestion(DNSQuestion.java:245)

07-29 10:38:13.099: W/DNSStateTask(28769):  at javax.jmdns.impl.tasks.state.Prober.buildOutgoingForInfo(Prober.java:131)

07-29 10:38:13.099: W/DNSStateTask(28769):  at javax.jmdns.impl.tasks.state.DNSStateTask.run(DNSStateTask.java:125)

07-29 10:38:13.099: W/DNSStateTask(28769):  at java.util.Timer$TimerImpl.run(Timer.java:284)

07-29 10:38:13.104: W/JmDNSImpl(28769): RECOVERING
07-29 10:38:13.119: W/DNSStateTask(28769): Canceler(192-168-2-2.local.).run() exception 
07-29 10:38:13.119: W/DNSStateTask(28769): java.lang.StringIndexOutOfBoundsException: length=37; regionStart=0; regionLength=-1

07-29 10:38:13.119: W/DNSStateTask(28769):  at java.lang.String.startEndAndLength(String.java:593)

07-29 10:38:13.119: W/DNSStateTask(28769):  at java.lang.String.substring(String.java:1474)

07-29 10:38:13.119: W/DNSStateTask(28769):  at javax.jmdns.impl.ServiceInfoImpl.decodeQualifiedNameMapForType(ServiceInfoImpl.java:292)

07-29 10:38:13.119: W/DNSStateTask(28769):  at javax.jmdns.impl.DNSEntry.<init>(DNSEntry.java:47)

07-29 10:38:13.119: W/DNSStateTask(28769):  at javax.jmdns.impl.DNSRecord.<init>(DNSRecord.java:46)

07-29 10:38:13.119: W/DNSStateTask(28769):  at javax.jmdns.impl.DNSRecord$Service.<init>(DNSRecord.java:647)

07-29 10:38:13.119: W/DNSStateTask(28769):  at javax.jmdns.impl.ServiceInfoImpl.answers(ServiceInfoImpl.java:1195)

07-29 10:38:13.119: W/DNSStateTask(28769):  at javax.jmdns.impl.tasks.state.Canceler.buildOutgoingForInfo(Canceler.java:117)

07-29 10:38:13.119: W/DNSStateTask(28769):  at javax.jmdns.impl.tasks.state.DNSStateTask.run(DNSStateTask.java:125)

07-29 10:38:13.119: W/DNSStateTask(28769):  at java.util.Timer$TimerImpl.run(Timer.java:284)

誰かが私が間違っていることや別のアプローチを説明してくれますか? サービスの作成に適用する文字列は、アプリケーションの早い段階でサービスを登録するために使用されるため、間違いなく有効です。

4

1 に答える 1

5

私も同じ問題を抱えていました。ServiceInfo.create() は、イベント タイプが無効であることを適切に通知しないことがわかりました。私の場合、「_http._tcp」を送信していました。イベントタイプとして。イベントタイプを「_http._tcp.local」に変更すると、すべてが完全に機能します。それが役立つことを願っています。

于 2014-07-11T04:07:41.397 に答える