|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object | +--com.oroinc.net.SocketClient
The SocketClient provides the basic operations that are required of client objects accessing sockets. It is meant to be subclassed to avoid having to rewrite the same code over and over again to open a socket, close a socket, set timeouts, etc. Of special note is the setSocketFactory method, which allows you to control the type of Socket the SocketClient creates for initiating network connections. This is especially useful for adding SSL or proxy support as well as better support for applets. For example, you could create a SocketFactory that requests browser security capabilities before creating a socket. All classes derived from SocketClient should use the _socketFactory_ member variable to create Socket and ServerSocket instances rather than instanting them by directly invoking a constructor. By honoring this contract you guarantee that a user will always be able to provide his own Socket implementations by substituting his own SocketFactory.
SocketFactory
Field Summary | |
protected int |
_defaultPort_
The default port the client should connect to. |
protected java.io.InputStream |
_input_
The socket's InputStream. |
protected boolean |
_isConnected_
A status variable indicating if the client's socket is currently open. |
protected java.io.OutputStream |
_output_
The socket's OutputStream. |
protected java.net.Socket |
_socket_
The socket used for the connection. |
protected SocketFactory |
_socketFactory_
The socket's SocketFactory. |
protected int |
_timeout_
The timeout to use after opening a socket. |
static java.lang.String |
NETASCII_EOL
The end of line character sequence used by most IETF protocols. |
Constructor Summary | |
SocketClient()
Default constructor for SocketClient. |
Method Summary | |
protected void |
_connectAction_()
Because there are so many connect() methods, the _connectAction_() method is provided as a means of performing some action immediately after establishing a connection, rather than reimplementing all of the connect() methods. |
void |
connect(java.net.InetAddress host)
Opens a Socket connected to a remote host at the current default port and originating from the current host at a system assigned port. |
void |
connect(java.net.InetAddress host,
int port)
Opens a Socket connected to a remote host at the specified port and originating from the current host at a system assigned port. |
void |
connect(java.net.InetAddress host,
int port,
java.net.InetAddress localAddr,
int localPort)
Opens a Socket connected to a remote host at the specified port and originating from the specified local address and port. |
void |
connect(java.lang.String hostname)
Opens a Socket connected to a remote host at the current default port and originating from the current host at a system assigned port. |
void |
connect(java.lang.String hostname,
int port)
Opens a Socket connected to a remote host at the specified port and originating from the current host at a system assigned port. |
void |
connect(java.lang.String hostname,
int port,
java.net.InetAddress localAddr,
int localPort)
Opens a Socket connected to a remote host at the specified port and originating from the specified local address and port. |
void |
disconnect()
Disconnects the socket connection. |
int |
getDefaultPort()
Returns the current value of the default port (stored in _defaultPort_ ). |
int |
getDefaultTimeout()
Returns the default timeout in milliseconds that is used when opening a socket. |
java.net.InetAddress |
getLocalAddress()
Returns the local address to which the client's socket is bound. |
int |
getLocalPort()
Returns the port number of the open socket on the local host used for the connection. |
java.net.InetAddress |
getRemoteAddress()
|
int |
getRemotePort()
Returns the port number of the remote host to which the client is connected. |
int |
getSoLinger()
Returns the current SO_LINGER timeout of the currently opened socket. |
int |
getSoTimeout()
Returns the timeout in milliseconds of the currently opened socket. |
boolean |
getTcpNoDelay()
Returns true if Nagle's algorithm is enabled on the currently opened socket. |
boolean |
isConnected()
Returns true if the client is currently connected to a server. |
void |
setDefaultPort(int port)
Sets the default port the SocketClient should connect to when a port is not specified. |
void |
setDefaultTimeout(int timeout)
Set the default timeout in milliseconds to use when opening a socket. |
void |
setSocketFactory(SocketFactory factory)
Sets the SocketFactory used by the SocketClient to open socket connections. |
void |
setSoLinger(boolean on,
int val)
Sets the SO_LINGER timeout on the currently opened socket. |
void |
setSoTimeout(int timeout)
Set the timeout in milliseconds of a currently open connection. |
void |
setTcpNoDelay(boolean on)
Enables or disables the Nagle's algorithm (TCP_NODELAY) on the currently opened socket. |
boolean |
verifyRemote(java.net.Socket socket)
Verifies that the remote end of the given socket is connected to the the same host that the SocketClient is currently connected to. |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
public static final java.lang.String NETASCII_EOL
protected int _timeout_
protected java.net.Socket _socket_
protected boolean _isConnected_
protected int _defaultPort_
protected java.io.InputStream _input_
protected java.io.OutputStream _output_
protected SocketFactory _socketFactory_
Constructor Detail |
public SocketClient()
Method Detail |
protected void _connectAction_() throws java.io.IOException
This method sets the timeout on the just opened socket to the default timeout set by setDefaultTimeout() , sets _input_ and _output_ to the socket's InputStream and OutputStream respectively, and sets _isConnected_ to true.
Subclasses overriding this method should start by calling
super._connectAction_()
first to ensure the
initialization of the aforementioned protected variables.
public void connect(java.net.InetAddress host, int port) throws java.net.SocketException, java.io.IOException
host
- The remote host.port
- The port to connect to on the remote host.java.net.SocketException
- If the socket timeout could not be set.java.io.IOException
- If the socket could not be opened. In most
cases you will only want to catch IOException since SocketException is
derived from it.public void connect(java.lang.String hostname, int port) throws java.net.SocketException, java.io.IOException
hostname
- The name of the remote host.port
- The port to connect to on the remote host.java.net.SocketException
- If the socket timeout could not be set.java.io.IOException
- If the socket could not be opened. In most
cases you will only want to catch IOException since SocketException is
derived from it.java.net.UnknownHostException
- If the hostname cannot be resolved.public void connect(java.net.InetAddress host, int port, java.net.InetAddress localAddr, int localPort) throws java.net.SocketException, java.io.IOException
host
- The remote host.port
- The port to connect to on the remote host.localAddr
- The local address to use.localPort
- The local port to use.java.net.SocketException
- If the socket timeout could not be set.java.io.IOException
- If the socket could not be opened. In most
cases you will only want to catch IOException since SocketException is
derived from it.public void connect(java.lang.String hostname, int port, java.net.InetAddress localAddr, int localPort) throws java.net.SocketException, java.io.IOException
hostname
- The name of the remote host.port
- The port to connect to on the remote host.localAddr
- The local address to use.localPort
- The local port to use.java.net.SocketException
- If the socket timeout could not be set.java.io.IOException
- If the socket could not be opened. In most
cases you will only want to catch IOException since SocketException is
derived from it.java.net.UnknownHostException
- If the hostname cannot be resolved.public void connect(java.net.InetAddress host) throws java.net.SocketException, java.io.IOException
host
- The remote host.java.net.SocketException
- If the socket timeout could not be set.java.io.IOException
- If the socket could not be opened. In most
cases you will only want to catch IOException since SocketException is
derived from it.public void connect(java.lang.String hostname) throws java.net.SocketException, java.io.IOException
hostname
- The name of the remote host.java.net.SocketException
- If the socket timeout could not be set.java.io.IOException
- If the socket could not be opened. In most
cases you will only want to catch IOException since SocketException is
derived from it.java.net.UnknownHostException
- If the hostname cannot be resolved.public void disconnect() throws java.io.IOException
java.io.IOException
- If there is an error closing the socket.public boolean isConnected()
public void setDefaultPort(int port)
port
- The default port to set.public int getDefaultPort()
public void setDefaultTimeout(int timeout)
timeout
- The timeout in milliseconds to use for the socket
connection.public int getDefaultTimeout()
public void setSoTimeout(int timeout) throws java.net.SocketException
timeout
- The timeout in milliseconds to use for the currently
open socket connection.java.net.SocketException
- If the operation fails.public int getSoTimeout() throws java.net.SocketException
java.net.SocketException
- If the operation fails.public void setTcpNoDelay(boolean on) throws java.net.SocketException
on
- True if Nagle's algorithm is to be enabled, false if not.java.net.SocketException
- If the operation fails.public boolean getTcpNoDelay() throws java.net.SocketException
java.net.SocketException
- If the operation fails.public void setSoLinger(boolean on, int val) throws java.net.SocketException
on
- True if linger is to be enabled, false if not.val
- The linger timeout (in hundredths of a second?)java.net.SocketException
- If the operation fails.public int getSoLinger() throws java.net.SocketException
java.net.SocketException
- If the operation fails.public int getLocalPort()
public java.net.InetAddress getLocalAddress()
public int getRemotePort()
public java.net.InetAddress getRemoteAddress()
public boolean verifyRemote(java.net.Socket socket)
public void setSocketFactory(SocketFactory factory)
factory
- The new SocketFactory the SocketClient should use.
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |