Próbuję uruchomić aplikację przy użyciu usługi Android Native Service Discovery, ale czasami po uruchomieniu aplikacji nie wykrywa wszystkich usług z mojej sieci. Używam kodu od https://github.com/joeluchoa/nsd za pomocą czterech nexusów galaktyk, a większość razy każdy z nich odkrywa różną liczbę usług w tym samym czasie.Android NSD nie odkrywa wszystkich usług
Zasadniczo biegnę usługę z ServerSocket:
ServerSocket server = new ServerSocket(0);
Log.i(TAG, "IP " + server.getInetAddress()
+ ", running on port " + server.getLocalPort());
Intent intent = new Intent(MySocket.this,
MyPresence.class);
intent.putExtra("PORT", server.getLocalPort());
startService(intent);
Potem publikuje je z wykorzystaniem metody RegisterService z NsdManager:
NsdServiceInfo serviceInfo = new NsdServiceInfo();
serviceInfo.setServiceName(Build.SERIAL + "-" + new Date().getTime());
serviceInfo.setServiceType(SERVICE_TYPE);
serviceInfo.setPort(port);
mNsdManager.registerService(serviceInfo, NsdManager.PROTOCOL_DNS_SD,
mRegistrationListener);
Aby odkryć usługi używam discoverServices metodę z NsdManager:
mNsdManager.discoverServices(SERVICE_TYPE, NsdManager.PROTOCOL_DNS_SD,
mDiscoveryListener);
Z mDiscoveryListener w następujący sposób:
mDiscoveryListener = new NsdManager.DiscoveryListener() {
@Override
public void onDiscoveryStarted(String regType) {
Log.d(TAG, "Service discovery started");
}
@Override
public void onServiceFound(NsdServiceInfo service) {
Log.d(TAG, "Service discovery success");
Log.d(TAG, String.format("%s %s %s %d",
service.getServiceName(), service.getServiceType(),
service.getHost(), service.getPort()));
if (!service.getServiceType().contains(SERVICE_TYPE)) {
Log.d(TAG,
"Unknown Service Type: " + service.getServiceType());
} else if (service.getServiceName().equals(mServiceName)) {
Log.d(TAG, "Same machine: " + mServiceName);
} else {
mNsdManager.resolveService(service, mResolveListener);
}
}
@Override
public void onServiceLost(NsdServiceInfo service) {
Log.e(TAG, "service lost" + service);
}
@Override
public void onDiscoveryStopped(String serviceType) {
Log.i(TAG, serviceType + " Discovery stopped: " + serviceType);
}
@Override
public void onStartDiscoveryFailed(String serviceType, int errorCode) {
Log.e(TAG, serviceType + " Discovery failed: Error code:"
+ errorCode);
mNsdManager.stopServiceDiscovery(this);
}
@Override
public void onStopDiscoveryFailed(String serviceType, int errorCode) {
Log.e(TAG, serviceType + " Discovery failed: Error code:"
+ errorCode);
mNsdManager.stopServiceDiscovery(this);
}
};
Czy robię coś nie tak? Czy ktoś zna rozwiązanie lub obejście tego problemu?
I camer acros poście, starając się naprawić NPE, który wydaje się popup, kiedy mam dwóch urządzeń w sieci o tej samej informacji NSD ... Tak, I don” t masz dla ciebie jeszcze odpowiedź, ale zauważam, że próbujesz uzyskać informacje, których nie rozwiązałeś w swoim logu. –
Powszechną praktyką dla wszystkich programistów jest śledzenie tego, że za pomocą polecenia try catch lub wypisz wszystkie zmienne, aby znaleźć błędy, –
dopiero odkrywasz usługi SERVICE_TYPE, które w tym przykładzie są serwerami http. –