public class Proxy extends Object
This class represents a proxy setting, typically a type (http, socks) and a socket address. A Proxy
is an immutable object.
ProxySelector
Modifier and Type | Class and Description |
---|---|
static class |
Proxy.Type Represents the proxy type. |
public static final Proxy NO_PROXY
A proxy setting that represents a DIRECT
connection, basically telling the protocol handler not to use any proxying. Used, for instance, to create sockets bypassing any other global proxy settings (like SOCKS):
Socket s = new Socket(Proxy.NO_PROXY);
public Proxy(Proxy.Type type, SocketAddress sa)
Creates an entry representing a PROXY connection. Certain combinations are illegal. For instance, for types Http, and Socks, a SocketAddress must be provided.
Use the Proxy.NO_PROXY
constant for representing a direct connection.
type
- the Type
of the proxysa
- the SocketAddress
for that proxyIllegalArgumentException
- when the type and the address are incompatiblepublic Proxy.Type type()
Returns the proxy type.
public SocketAddress address()
Returns the socket address of the proxy, or null
if its a direct connection.
SocketAddress
representing the socket end point of the proxypublic String toString()
Constructs a string representation of this Proxy. This String is constructed by calling toString() on its type and concatenating " @ " and the toString() result from its address if its type is not DIRECT
.
public final boolean equals(Object obj)
Compares this object against the specified object. The result is true
if and only if the argument is not null
and it represents the same proxy as this object.
Two instances of Proxy
represent the same address if both the SocketAddresses and type are equal.
equals
in class Object
obj
- the object to compare against.true
if the objects are the same; false
otherwise.InetSocketAddress.equals(java.lang.Object)
public final int hashCode()
Returns a hashcode for this Proxy.
hashCode
in class Object
Object.equals(java.lang.Object)
, System.identityHashCode(java.lang.Object)
© 1993–2017, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.