2013-07-29 10 views
6

私はかなり単純な問題だと思ったことがあります。サービスの再登録JMDNS

私は正常に処理したサービスをブロードキャストするためにJmDNSを使用しようとしていますが、アプリケーションが一時停止しているときにサービスを登録解除してから、アプリケーションを再開するときにサービスを再登録します。

しかし、私はこれを行う問題に遭遇しています。コードは以下の通りです:私が間違っていたり、別のアプローチをやっている

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) 

は、誰かが私に説明することができます:

//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"); 
    } 

私はこれをしようとしたとき、私は私を混乱され、このエラーログを取得します。私がサービス作成に適用する文字列は、アプリケーションで以前にサービスを登録するために使用されるため、間違いなく有効です。

答えて

5

私は同じ問題を抱えていました。 ServiceInfo.create()は、イベントタイプが無効であることを通知しません。私の場合、私は "_http._tcp"を送っていました。イベントタイプとしてイベントタイプを「_http._tcp.local」に変更したところ、すべてが完全に機能しました。希望が役立ちます。

+0

イベントタイプ/サービスタイプを "_http._tcp.local"として使用すると、すべてのサービスを適切に取得できますか? – sandeepmaaram

関連する問題