public classJMXServiceURLextendsObjectimplementsSerializable
The address of a JMX API connector server. Instances of this class are immutable.
The address is anAbstract Service URL for SLP, as defined in RFC 2609 and amended by RFC 3111. It must look like this:
service:jmx:protocol:sapHere,protocol is the transport protocol to be used to connect to the connector server. It is a string of one or more ASCII characters, each of which is a letter, a digit, or one of the characters+ or-. The first character must be a letter. Uppercase letters are converted into lowercase ones.
sap is the address at which the connector server is found. This address uses a subset of the syntax defined by RFC 2609 for IP-based protocols. It is a subset because theuser@host syntax is not supported.
The other syntaxes defined by RFC 2609 are not currently supported by this class.
The supported syntax is:
//[host[:port]][url-path]Square brackets[] indicate optional parts of the address. Not all protocols will recognize all optional parts.
Thehost is a host name, an IPv4 numeric host address, or an IPv6 numeric address enclosed in square brackets.
Theport is a decimal port number. 0 means a default or anonymous port, depending on the protocol.
Thehost andport can be omitted. Theport cannot be supplied without ahost.
Theurl-path, if any, begins with a slash (/) or a semicolon (;) and continues to the end of the address. It can contain attributes using the semicolon syntax specified in RFC 2609. Those attributes are not parsed by this class and incorrect attribute syntax is not detected.
Although it is legal according to RFC 2609 to have aurl-path that begins with a semicolon, not all implementations of SLP allow it, so it is recommended to avoid that syntax.
Case is not significant in the initialservice:jmx:protocol string or in the host part of the address. Depending on the protocol, case can be significant in theurl-path.
| Constructor | Description |
|---|---|
JMXServiceURL(String serviceURL) | Constructs a JMXServiceURL by parsing a Service URL string. |
JMXServiceURL(String protocol,String host, int port) | Constructs a JMXServiceURL with the given protocol, host, and port. |
JMXServiceURL(String protocol,String host, int port,String urlPath) | Constructs a JMXServiceURL with the given parts. |
| Modifier and Type | Method | Description |
|---|---|---|
boolean | equals(Object obj) | Indicates whether some other object is equal to this one. |
String | getHost() | The host part of the Service URL. |
int | getPort() | The port of the Service URL. |
String | getProtocol() | The protocol part of the Service URL. |
String | getURLPath() | The URL Path part of the Service URL. |
int | hashCode() | Returns a hash code value for the object. |
String | toString() | The string representation of this Service URL. |
public JMXServiceURL(String serviceURL) throwsMalformedURLException
Constructs aJMXServiceURL by parsing a Service URL string.
serviceURL - the URL string to be parsed.NullPointerException - ifserviceURL is null.MalformedURLException - ifserviceURL does not conform to the syntax for an Abstract Service URL or if it is not a valid name for a JMX Remote API service. AJMXServiceURL must begin with the string"service:jmx:" (case-insensitive). It must not contain any characters that are not printable ASCII characters.public JMXServiceURL(String protocol,String host, int port) throwsMalformedURLException
Constructs aJMXServiceURL with the given protocol, host, and port. This constructor is equivalent toJMXServiceURL(protocol, host, port, null).
protocol - the protocol part of the URL. If null, defaults tojmxmp.host - the host part of the URL. If null, defaults to the local host name, as determined byInetAddress.getLocalHost().getHostName(). If it is a numeric IPv6 address, it can optionally be enclosed in square brackets[].port - the port part of the URL.MalformedURLException - if one of the parts is syntactically incorrect, or ifhost is null and it is not possible to find the local host name, or ifport is negative.public JMXServiceURL(String protocol,String host, int port,String urlPath) throwsMalformedURLException
Constructs aJMXServiceURL with the given parts.
protocol - the protocol part of the URL. If null, defaults tojmxmp.host - the host part of the URL. If null, defaults to the local host name, as determined byInetAddress.getLocalHost().getHostName(). If it is a numeric IPv6 address, it can optionally be enclosed in square brackets[].port - the port part of the URL.urlPath - the URL path part of the URL. If null, defaults to the empty string.MalformedURLException - if one of the parts is syntactically incorrect, or ifhost is null and it is not possible to find the local host name, or ifport is negative.public String getProtocol()
The protocol part of the Service URL.
public String getHost()
The host part of the Service URL. If the Service URL was constructed with the constructor that takes a URL string parameter, the result is the substring specifying the host in that URL. If the Service URL was constructed with a constructor that takes a separate host parameter, the result is the string that was specified. If that string was null, the result isInetAddress.getLocalHost().getHostName().
In either case, if the host was specified using the[...] syntax for numeric IPv6 addresses, the square brackets are not included in the return value here.
public int getPort()
The port of the Service URL. If no port was specified, the returned value is 0.
public String getURLPath()
The URL Path part of the Service URL. This is an empty string, or a string beginning with a slash (/), or a string beginning with a semicolon (;).
public String toString()
The string representation of this Service URL. If the value returned by this method is supplied to theJMXServiceURL constructor, the resultant object is equal to this one.
Thehost part of the returned string is the value returned bygetHost(). If that value specifies a numeric IPv6 address, it is surrounded by square brackets[].
Theport part of the returned string is the value returned bygetPort() in its shortest decimal form. If the value is zero, it is omitted.
public boolean equals(Object obj)
Indicates whether some other object is equal to this one. This method returns true if and only ifobj is an instance ofJMXServiceURL whosegetProtocol(),getHost(),getPort(), andgetURLPath() methods return the same values as for this object. The values forgetProtocol() andgetHost() can differ in case without affecting equality.
equals in class Objectobj - the reference object with which to compare.true if this object is the same as theobj argument;false otherwise.Object.hashCode(),HashMappublic int hashCode()
ObjectHashMap. The general contract ofhashCode is:
hashCode method must consistently return the same integer, provided no information used inequals comparisons on the object is modified. This integer need not remain consistent from one execution of an application to another execution of the same application.equals(Object) method, then calling thehashCode method on each of the two objects must produce the same integer result.Object.equals(java.lang.Object) method, then calling thehashCode method on each of the two objects must produce distinct integer results. However, the programmer should be aware that producing distinct integer results for unequal objects may improve the performance of hash tables. As much as is reasonably practical, the hashCode method defined by classObject does return distinct integers for distinct objects. (This is typically implemented by converting the internal address of the object into an integer, but this implementation technique is not required by the Java™ programming language.)
hashCode in class ObjectObject.equals(java.lang.Object),System.identityHashCode(java.lang.Object)