2016-04-22 10 views
2

初めてAndroidでIPディスカバリを実行しようとしています。私はhttp://developer.android.com/training/connect-devices-wirelessly/nsd.html#discoverを使用し、コードを書いた。私はデバイスを登録するのではなく、ネットワーク内のサービスを発見するだけです。エミュレータまたはデバイスでプロジェクトを実行すると、onDiscoveryStarted()が呼び出されますが、onServiceFound()は呼び出されません。下記の私のコードを見つけてください。入力は非常に高く評価されます。ありがとう!Android NSD onServiceFound()が呼び出されない

public class MainActivity extends AppCompatActivity { 

    private Button discoverButton; 

    Context mContext; 

    NsdManager mNsdManager; 
    NsdManager.ResolveListener mResolveListener; 
    NsdManager.DiscoveryListener mDiscoveryListener; 
    NsdManager.RegistrationListener mRegistrationListener; 

    public static final String SERVICE_TYPE = "_http._tcp."; 
    public static final String TAG = "MyApp_MAIN_CLIENT"; 
    public String mServiceName = "MyApp"; 

    /* 
    * public static final String SERVICE_TYPE = "_http._tcp."; 
    public static final String TAG = "NsdHelper"; 
    public String mServiceName = "NsdChat"; 
    * */ 

    NsdServiceInfo mService; 
    private Handler mUpdateHandler; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 

     mNsdManager = (NsdManager) this.getSystemService(Context.NSD_SERVICE); 
     discoverButton = (Button) findViewById(R.id.netButton); 
     discoverButton.setOnClickListener(new View.OnClickListener() { 
      public void onClick(android.view.View v) { 
       initializeDiscoveryListener(); 
       initializeResolveListener(); 
       discoverServices(); 

      } 
     }); 

    } 

    public void discoverServices() { 
     mNsdManager.discoverServices(
       SERVICE_TYPE, NsdManager.PROTOCOL_DNS_SD, mDiscoveryListener); 
    } 


    public void initializeDiscoveryListener() { 

     // Instantiate a new DiscoveryListener 
     mDiscoveryListener = new NsdManager.DiscoveryListener() { 

      // Called as soon as service discovery begins. 
      @Override 
      public void onDiscoveryStarted(String regType) { 
       Log.d(TAG, "Service discovery started"); 
      } 

      @Override 
      public void onServiceFound(NsdServiceInfo service) { 
       // A service was found! Do something with it. 
       Log.d(TAG, "Service discovery success" + service); 
       if (!service.getServiceType().equals(SERVICE_TYPE)) { 
        // Service type is the string containing the protocol and 
        // transport layer for this service. 
        Log.d(TAG, "Unknown Service Type: " + service.getServiceType()); 
       } /*else if (service.getServiceName().equals(mServiceName)) { 
        // The name of the service tells the user what they'd be 
        // connecting to. It could be "Bob's Chat App". 
        Log.d(TAG, "Same machine: " + mServiceName); 
       } 
       //else if (service.getServiceName().contains("NsdChat")){*/ 
       else{ 
        mNsdManager.resolveService(service, mResolveListener); 
       } 
      } 

      @Override 
      public void onServiceLost(NsdServiceInfo service) { 
       // When the network service is no longer available. 
       // Internal bookkeeping code goes here. 
       Log.e(TAG, "service lost" + service); 
      } 

      @Override 
      public void onDiscoveryStopped(String serviceType) { 
       Log.i(TAG, "Discovery stopped: " + serviceType); 
      } 

      @Override 
      public void onStartDiscoveryFailed(String serviceType, int errorCode) { 
       Log.e(TAG, "Discovery failed: Error code:" + errorCode); 
       mNsdManager.stopServiceDiscovery(this); 
      } 

      @Override 
      public void onStopDiscoveryFailed(String serviceType, int errorCode) { 
       Log.e(TAG, "Discovery failed: Error code:" + errorCode); 
       mNsdManager.stopServiceDiscovery(this); 
      } 
     }; 
    }// end of initializeListener() 


    public void initializeResolveListener() { 
     mResolveListener = new NsdManager.ResolveListener() { 

      @Override 
      public void onResolveFailed(NsdServiceInfo serviceInfo, int errorCode) { 
       Log.e(TAG, "Resolve failed" + errorCode); 
      } 

      @Override 
      public void onServiceResolved(NsdServiceInfo serviceInfo) { 
       Log.e(TAG, "Resolve Succeeded. " + serviceInfo); 

       if (serviceInfo.getServiceName().equals(mServiceName)) { 
        Log.d(TAG, "Same IP."); 
        return; 
       } 
       mService = serviceInfo; 
       int port = mService.getPort(); 
       InetAddress host = mService.getHost(); 
       Log.d(TAG,host.toString()); 
      } 
     }; 
    }//end of initializeResolveListener 


    @Override 
    protected void onPause() { 
     super.onPause(); 
     stopDiscovery(); 
     tearDown(); 

    } 

    @Override 
    protected void onResume() { 
     super.onResume(); 
     discoverServices(); 
    } 

    @Override 
    protected void onDestroy() { 
     tearDown(); 
     super.onDestroy(); 
    } 

    public void stopDiscovery() { 
     mNsdManager.stopServiceDiscovery(mDiscoveryListener); 
    } 


    public void tearDown() { 
     mNsdManager.unregisterService(mRegistrationListener); 
    } 
} 
+0

_「私は、ネットワーク内のサービスを発見、デバイスを登録するわけではない」のに役立ちます。それが理由。登録されていないサービスは検出できません。 1台のデバイスが他のデバイスが検出するサービスを登録する必要があります(NSDサンプルに関するアドバイス:同じデバイス上でサービスを登録して検出しないでください) – Onik

+0

Android NSDドキュメントでは、 。デバイスを登録しない場合は、手順2:その他のサービスの検出に進みます。 – pws35

+0

"_http._tcp"から最後のドットを削除してください。 - > "_http._tcp"; – Dmitry

答えて

1

おそらく、この投稿の年齢のために、私はあなたがすでに解決策を見つけたことを願っています。

私の経験では、Androidエミュレータ(APIレベル25)は完全なネットワークスタックを提供しておらず、NSDによるサービスディスカバリは機能していないことです。

実際のデバイス(Android TVやタブレットなど)でデバッグするように切り替えた後、NSD/Bonjourのような設定全体が機能していました。 DiscoveryListenerとResolveListenerのメソッドが呼び出され、IPとポート(私の場合)が取得されました。 NdsManager documentation pageから

0

APIは現在、DNSベースのサービスの発見と発見 が現在のマルチキャストDNS経由のローカルネットワークに限定されているサポートしています。このLocal networking limitations emulator docs pageから

現在、エミュレータは、IGMPやマルチキャストをサポートしていません。

希望これは_あなたが

関連する問題