2016-04-22 49 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

_「我不是註冊設備,只要發現服務在網絡中」 _。這就是原因。您無法發現尚未註冊的服務。一個設備應該註冊其他設備將發現的服務......(關於'NSD'示例的建議:不要在同一設備上註冊和發現服務) – Onik

+0

Android NSD文檔特別指出'註冊'步驟是可選的。如果您不想註冊設備,請轉至步驟2:發現其他服務 – pws35

+0

嘗試從「_http._tcp。」中刪除最後一個點。 - >「_http._tcp」; – Dmitry

回答

1

可能是由於這篇文章的年齡,我希望你已經找到了解決辦法。

如果不是,我的經驗是Android模擬器(API級別25)不提供完整的網絡堆棧,並且通過NSD的服務發現不起作用。

我切換到真正的設備(如Android電視或平板電腦)調試,然後我整個NSD/Bonjour的設置工作。 DiscoveryListener和ResolveListener的方法被調用,並檢索到IP和端口(在我的情況下)。