javax.net.ssl
Class SSLSocket

java.lang.Object
  |
  +--java.net.Socket
        |
        +--javax.net.ssl.SSLSocket

public abstract class SSLSocket
extends Socket

SSLSocket is a class extended by sockets which support the "Secure Sockets Layer" (SSL) or IETF "Transport Layer Security" (TLS) protocols. Such sockets are normal stream sockets (java.net.Socket), but they add a layer of security protections over the underlying network transport protocol, such as TCP. Those protections include:

These kinds of protection are specified by a "cipher suite", which is a combination of cryptographic algorithms used by a given SSL connection. For example, how is integrity protection provided (what kind of message digest is used), how and whether the traffic is privacy-protected, and how authentication keys are exchanged.

The cipher suite used is established by a negotiation process, between SSL clients and servers, which is called "handshaking". The goal of this process is to create or rejoin a "session", which may protect many connections over time. After handshaking has completed, you can get access to session attributes using the getSession method. Handshaking is fully transparent in most cases, but may be explicitly initiated.

You may register to receive event notification of handshake completion, using the standard Java Beans event model. This involves the use of two additional classes. HandshakeCompletedEvent objects are passed to HandshakeCompletedListener instances, which are implemented by users of this API.


When SSL connections are first set up, no security is provided. However, security is always provided by the time that application data is sent over the connection. Before sending such data, application programs may then express preferences for what cipher suites may be used in communication. SSL code performs a negotiation as part of preparing to send data. Some cipher suite that is supported by both sides of the SSL connection will be used. If there is no such suite, no SSL connection will be established, and no data can be exchanged.

Implementation defaults are required to enable use only of cipher suites which authenticate servers, and which provide confidentiality. The client and server must both agree on a common cipher suite in order to communicate. Only if both explicitly agree to unauthenticated or nonprivate communications will those security protections not exist.

There are two groups of cipher suites which you will need to know about when managing cipher suites, in addition to the default list and the active suite associated with the connection's session:

See Also:
Socket, SSLServerSocket, SSLSocketFactory

Constructor Summary
protected SSLSocket()
          Used only by subclasses.
protected SSLSocket(InetAddress address, int port)
          Used only by subclasses.
protected SSLSocket(InetAddress address, int port, InetAddress clientAddress, int clientPort)
          Used only by subclasses.
protected SSLSocket(String host, int port)
          Used only by subclasses.
protected SSLSocket(String host, int port, InetAddress clientAddress, int clientPort)
          Used only by subclasses.
 
Method Summary
abstract  void addHandshakeCompletedListener(HandshakeCompletedListener listener)
          Registers an event listener to receive notifications that an SSL handshake has completed on this connection.
abstract  String[] getEnabledCipherSuites()
          Returns the names of the SSL cipher suites which are currently enabled for use on this connection.
abstract  boolean getEnableSessionCreation()
          Returns true if new SSL sessions may be established by this socket.
abstract  boolean getNeedClientAuth()
          Returns true if the socket will require client authentication.
abstract  SSLSession getSession()
          Returns the the SSL Session in use by this connection.
abstract  String[] getSupportedCipherSuites()
          Returns the names of the cipher suites which could be enabled for use on an SSL connection.
abstract  boolean getUseClientMode()
          Returns true if the socket is set to use client mode in its first handshake.
abstract  void removeHandshakeCompletedListener(HandshakeCompletedListener listener)
          Removes a previously registered handshake completion listener.
abstract  void setEnabledCipherSuites(String[] suites)
          Controls which particular cipher suites are enabled for use on this connection.
abstract  void setEnableSessionCreation(boolean flag)
          Controls whether new SSL sessions may be established by this socket.
abstract  void setNeedClientAuth(boolean need)
          Configures the socket to require client authentication.
abstract  void setUseClientMode(boolean mode)
          Configures the socket to use client (or server) mode in its first handshake.
abstract  void startHandshake()
          Starts an SSL handshake on this connection.
 
Methods inherited from class java.net.Socket
close, getInetAddress, getInputStream, getLocalAddress, getLocalPort, getOutputStream, getPort, getReceiveBufferSize, getSendBufferSize, getSoLinger, getSoTimeout, getTcpNoDelay, setReceiveBufferSize, setSendBufferSize, setSocketImplFactory, setSoLinger, setSoTimeout, setTcpNoDelay, toString
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 

Constructor Detail

SSLSocket

protected SSLSocket()
Used only by subclasses. Constructs an uninitialized, unconnected TCP socket.

SSLSocket

protected SSLSocket(String host,
                    int port)
             throws IOException,
                    UnknownHostException
Used only by subclasses. Constructs a TCP connection to a named host at a specified port. This acts as the SSL client.
Parameters:
host - name of the host with which to connect
port - number of the server's port

SSLSocket

protected SSLSocket(InetAddress address,
                    int port)
             throws IOException,
                    UnknownHostException
Used only by subclasses. Constructs a TCP connection to a server at a specified address and port. This acts as the SSL client.
Parameters:
address - the server's host
port - its port

SSLSocket

protected SSLSocket(String host,
                    int port,
                    InetAddress clientAddress,
                    int clientPort)
             throws IOException,
                    UnknownHostException
Used only by subclasses. Constructs an SSL connection to a named host at a specified port, binding the client side of the connection a given address and port. This acts as the SSL client.
Parameters:
host - name of the host with which to connect
port - number of the server's port

SSLSocket

protected SSLSocket(InetAddress address,
                    int port,
                    InetAddress clientAddress,
                    int clientPort)
             throws IOException,
                    UnknownHostException
Used only by subclasses. Constructs an SSL connection to a server at a specified address and TCP port, binding the client side of the connection a given address and port. This acts as the SSL client.
Parameters:
address - the server's host
port - its port
Method Detail

getSupportedCipherSuites

public abstract String[] getSupportedCipherSuites()
Returns the names of the cipher suites which could be enabled for use on an SSL connection. Normally, only a subset of these will actually be enabled by default, since this list may include cipher suites which do not meet quality of service requirements for those defaults. Such cipher suites are useful in specialized applications.
Returns:
an array of cipher suite names

getEnabledCipherSuites

public abstract String[] getEnabledCipherSuites()
Returns the names of the SSL cipher suites which are currently enabled for use on this connection. When an SSL socket is first created, all enabled cipher suites support a minium quality of service. Thus, in some environments this value might be empty.
Returns:
an array of cipher suite names
See Also:
setEnabledCipherSuites(java.lang.String[])

setEnabledCipherSuites

public abstract void setEnabledCipherSuites(String[] suites)
Controls which particular cipher suites are enabled for use on this connection. The cipher suites must have been listed by getSupportedCipherSuites() as being supported. Even if a suite has been enabled, it might never be used if no peer supports it, or the requisite certificates (and private keys) are not available.
Parameters:
suites - Names of all the cipher suites to enable.
Throws:
IllegalArgumentException - when one or more of the ciphers named by the parameter is not supported, or when the parameter is null.
See Also:
getEnabledCipherSuites()

getSession

public abstract SSLSession getSession()
Returns the the SSL Session in use by this connection. These can be long lived, and frequently correspond to an entire login session for some user. The session specifies a particular cipher suite which is being actively used by all connections in that session, as well as the identities of the session's client and server.

addHandshakeCompletedListener

public abstract void addHandshakeCompletedListener(HandshakeCompletedListener listener)
Registers an event listener to receive notifications that an SSL handshake has completed on this connection.
See Also:
startHandshake(), removeHandshakeCompletedListener(javax.net.ssl.HandshakeCompletedListener)

removeHandshakeCompletedListener

public abstract void removeHandshakeCompletedListener(HandshakeCompletedListener listener)
Removes a previously registered handshake completion listener.
Throws:
IllegalArgumentException - if the listener is not registered
See Also:
addHandshakeCompletedListener(javax.net.ssl.HandshakeCompletedListener)

startHandshake

public abstract void startHandshake()
                             throws IOException
Starts an SSL handshake on this connection. Common reasons include a need to use new encryption keys, to change cipher suites, or to initiate a new session. To force complete reauthentication, the current session could be invalidated before starting this handshake.

If data has already been sent on the connection, it continues to flow during this handshake. When the handshake completes, this will be signaled with an event. This method is synchronous for the initial handshake on a connection and returns when the negotiated handshake is complete. Some protocols may not support multiple handshakes on an existing socket and may throw an IOException.

Throws:
IOException - on a network level error
See Also:
addHandshakeCompletedListener(javax.net.ssl.HandshakeCompletedListener)

setUseClientMode

public abstract void setUseClientMode(boolean mode)
Configures the socket to use client (or server) mode in its first handshake. Servers normally authenticate themselves, and clients are not required to do so.
Parameters:
mode - true iff the socket should start its first handshake in "client" mode
Throws:
IllegalArgumentException - if the socket mode has been set

getUseClientMode

public abstract boolean getUseClientMode()
Returns true if the socket is set to use client mode in its first handshake.
Returns:
true iff the socket should start its first handshake in "client" mode
See Also:
setUseClientMode(boolean)

setNeedClientAuth

public abstract void setNeedClientAuth(boolean need)
Configures the socket to require client authentication. The socket must be a server mode socket.
Parameters:
need - true iff the server mode socket should request that the client authenticate itself.
Throws:
IllegalArgumentException - if the socket is not in server mode

getNeedClientAuth

public abstract boolean getNeedClientAuth()
Returns true if the socket will require client authentication. The socket must be a server mode socket.
Returns:
true iff the server mode socket should request that the client authenticate itself.
See Also:
setNeedClientAuth(boolean)

setEnableSessionCreation

public abstract void setEnableSessionCreation(boolean flag)
Controls whether new SSL sessions may be established by this socket.
Parameters:
flag - true indicates that sessions may be created; this is the default. false indicates that an existing session must be resumed.

getEnableSessionCreation

public abstract boolean getEnableSessionCreation()
Returns true if new SSL sessions may be established by this socket.
Returns:
true indicates that sessions may be created; this is the default. false indicates that an existing session must be resumed.