Package javax.jmdns
Interface JmmDNS
- All Superinterfaces:
AutoCloseable
,Closeable
- All Known Implementing Classes:
JmmDNSImpl
Java Multihomed Multicast DNS
Uses an underlyingJmDNS
instance for each InetAddress
found on this computer.This class will monitor network topology changes, and will create or destroy JmDNS instances as required. It is your responsibility to maintain services registration (hint: use a
NetworkTopologyListener
).Most of this class methods have no notion of transaction: if an Exception is raised in the middle of execution, you may be in an incoherent state.
Note: This API is experimental and may change in the future please let us know what work and what does not work in your application.
-
Nested Class Summary
Nested ClassesModifier and TypeInterfaceDescriptionstatic final class
JmmDNS.Factory enable the creation of new instance of JmmDNS. -
Method Summary
Modifier and TypeMethodDescriptionvoid
Listen to network changes.void
addServiceListener
(String type, ServiceListener listener) Listen for services of a given type.void
addServiceTypeListener
(ServiceTypeListener listener) Listen for service types.JmDNS[]
getDNS()
Return a list of all the registered JmDNS instancesString[]
Return the list HostName associated with this JmmDNS instance.Return the list of addresses of the interface to which this instance of JmmDNS is bound.Deprecated.String[]
getNames()
Return the names of the JmDNS instances.getServiceInfos
(String type, String name) Get service information.getServiceInfos
(String type, String name, boolean persistent) Get service information.getServiceInfos
(String type, String name, boolean persistent, long timeout) Get service information.getServiceInfos
(String type, String name, long timeout) Get service information.Returns a list of service infos of the specified type.Returns a list of service infos of the specified type.Map
<String, ServiceInfo[]> listBySubtype
(String type) Returns a list of service infos of the specified type sorted by subtype.Map
<String, ServiceInfo[]> listBySubtype
(String type, long timeout) Returns a list of service infos of the specified type sorted by subtype.Returns list of network change listenersvoid
registerService
(ServiceInfo info) Register a service.void
registerServiceType
(String type) Register a service type.void
Remove listener for network changes.void
removeServiceListener
(String type, ServiceListener listener) Remove listener for services of a given type.void
removeServiceTypeListener
(ServiceTypeListener listener) Remove listener for service types.void
requestServiceInfo
(String type, String name) Request service information.void
requestServiceInfo
(String type, String name, boolean persistent) Request service information.void
requestServiceInfo
(String type, String name, boolean persistent, long timeout) Request service information.void
requestServiceInfo
(String type, String name, long timeout) Request service information.void
Unregister all services.void
unregisterService
(ServiceInfo info) Unregister a service.
-
Method Details
-
getNames
String[] getNames()Return the names of the JmDNS instances.- Returns:
- list of name of the JmDNS
- See Also:
-
getHostNames
String[] getHostNames()Return the list HostName associated with this JmmDNS instance.- Returns:
- list of host names
- See Also:
-
getInetAddresses
Return the list of addresses of the interface to which this instance of JmmDNS is bound.- Returns:
- list of Internet Address
- Throws:
IOException
- See Also:
-
getInterfaces
Deprecated.do not use this implementation yields unpredictable results usegetInetAddresses()
Return the list of addresses of the interface to which this instance of JmmDNS is bound.- Returns:
- list of Internet Address
- Throws:
IOException
- See Also:
-
getDNS
JmDNS[] getDNS()Return a list of all the registered JmDNS instances- Returns:
- list of JmDNS instances
-
getServiceInfos
Get service information. If the information is not cached, the method will block until updated information is received on all DNS. Usage note: Do not call this method from the AWT event dispatcher thread. You will make the user interface unresponsive.- Parameters:
type
- fully qualified service type, such as_http._tcp.local.
.name
- unqualified service name, such asfoobar
.- Returns:
- list of service info. If no service info is found the list is empty.
- See Also:
-
getServiceInfos
Get service information. If the information is not cached, the method will block until updated information is received on all DNS. Usage note: If you call this method from the AWT event dispatcher thread, use a small timeout, or you will make the user interface unresponsive.- Parameters:
type
- full qualified service type, such as_http._tcp.local.
.name
- unqualified service name, such asfoobar
.timeout
- timeout in milliseconds. Typical timeout should be 5s.- Returns:
- list of service info. If no service info is found the list is empty.
- See Also:
-
getServiceInfos
Get service information. If the information is not cached, the method will block until updated information is received on all DNS. Usage note: If you call this method from the AWT event dispatcher thread, use a small timeout, or you will make the user interface unresponsive.- Parameters:
type
- full qualified service type, such as_http._tcp.local.
.name
- unqualified service name, such asfoobar
.persistent
- iftrue
ServiceListener.resolveService will be called whenever new new information is received.- Returns:
- list of service info. If no service info is found the list is empty.
- See Also:
-
getServiceInfos
Get service information. If the information is not cached, the method will block until updated information is received on all DNS. Usage note: If you call this method from the AWT event dispatcher thread, use a small timeout, or you will make the user interface unresponsive.- Parameters:
type
- full qualified service type, such as_http._tcp.local.
.name
- unqualified service name, such asfoobar
.persistent
- iftrue
ServiceListener.resolveService will be called whenever new new information is received.timeout
- timeout in milliseconds. Typical timeout should be 5s.- Returns:
- list of service info. If no service info is found the list is empty.
- See Also:
-
requestServiceInfo
Request service information. The information about the service is requested and the ServiceListener.resolveService method is called as soon as it is available.- Parameters:
type
- full qualified service type, such as_http._tcp.local.
.name
- unqualified service name, such asfoobar
.- See Also:
-
requestServiceInfo
Request service information. The information about the service is requested and the ServiceListener.resolveService method is called as soon as it is available.- Parameters:
type
- full qualified service type, such as_http._tcp.local.
.name
- unqualified service name, such asfoobar
.persistent
- iftrue
ServiceListener.resolveService will be called whenever new new information is received.- See Also:
-
requestServiceInfo
Request service information. The information about the service is requested and the ServiceListener.resolveService method is called as soon as it is available.- Parameters:
type
- full qualified service type, such as_http._tcp.local.
.name
- unqualified service name, such asfoobar
.timeout
- timeout in milliseconds- See Also:
-
requestServiceInfo
Request service information. The information about the service is requested and the ServiceListener.resolveService method is called as soon as it is available.- Parameters:
type
- full qualified service type, such as_http._tcp.local.
.name
- unqualified service name, such asfoobar
.persistent
- iftrue
ServiceListener.resolveService will be called whenever new new information is received.timeout
- timeout in milliseconds- See Also:
-
addServiceTypeListener
Listen for service types.- Parameters:
listener
- listener for service types- Throws:
IOException
- See Also:
-
removeServiceTypeListener
Remove listener for service types.- Parameters:
listener
- listener for service types- See Also:
-
addServiceListener
Listen for services of a given type. The type has to be a fully qualified type name such as_http._tcp.local.
.- Parameters:
type
- full qualified service type, such as_http._tcp.local.
.listener
- listener for service updates- See Also:
-
removeServiceListener
Remove listener for services of a given type.- Parameters:
type
- full qualified service type, such as_http._tcp.local.
.listener
- listener for service updates- See Also:
-
registerService
Register a service. The service is registered for access by other jmdns clients. The name of the service may be changed to make it unique.
Note the Service info is cloned for each network interface.- Parameters:
info
- service info to register- Throws:
IOException
- See Also:
-
unregisterService
Unregister a service. The service should have been registered.- Parameters:
info
- service info to remove- See Also:
-
unregisterAllServices
void unregisterAllServices()Unregister all services.- See Also:
-
registerServiceType
Register a service type. If this service type was not already known, all service listeners will be notified of the new service type. Service types are automatically registered as they are discovered.- Parameters:
type
- full qualified service type, such as_http._tcp.local.
.- See Also:
-
list
Returns a list of service infos of the specified type.- Parameters:
type
- Service type name, such as_http._tcp.local.
.- Returns:
- An array of service instance.
- See Also:
-
list
Returns a list of service infos of the specified type.- Parameters:
type
- Service type name, such as_http._tcp.local.
.timeout
- timeout in milliseconds. Typical timeout should be 6s.- Returns:
- An array of service instance.
- See Also:
-
listBySubtype
Returns a list of service infos of the specified type sorted by subtype. Any service that do not register a subtype is listed in the empty subtype section.- Parameters:
type
- Service type name, such as_http._tcp.local.
.- Returns:
- A dictionary of service info by subtypes.
- See Also:
-
listBySubtype
Returns a list of service infos of the specified type sorted by subtype. Any service that do not register a subtype is listed in the empty subtype section.- Parameters:
type
- Service type name, such as_http._tcp.local.
.timeout
- timeout in milliseconds. Typical timeout should be 6s.- Returns:
- A dictionary of service info by subtypes.
- See Also:
-
addNetworkTopologyListener
Listen to network changes.- Parameters:
listener
- listener for network changes
-
removeNetworkTopologyListener
Remove listener for network changes.- Parameters:
listener
- listener for network changes
-
networkListeners
NetworkTopologyListener[] networkListeners()Returns list of network change listeners- Returns:
- list of network change listeners
-
getInetAddresses()