- java.lang.Object
-
- java.net.ServerSocket
-
- javax.net.ssl.SSLServerSocket
-
- All Implemented Interfaces:
- Closeable, AutoCloseable
public abstract class SSLServerSocket extends ServerSocket
This class extendsServerSockets and provides secure server sockets using protocols such as the Secure Sockets Layer (SSL) or Transport Layer Security (TLS) protocols.Instances of this class are generally created using a
SSLServerSocketFactory. The primary function ofSSLServerSockets is to createSSLSockets byaccepting connections.SSLServerSockets contain several pieces of state data which are inherited by theSSLSocketat socket creation. These include the enabled cipher suites and protocols, whether client authentication is necessary, and whether created sockets should begin handshaking in client or server mode. The state inherited by the createdSSLSocketcan be overriden by calling the appropriate methods.- Since:
- 1.4
- See Also:
ServerSocket,SSLSocket
-
-
Constructor Summary
Constructors Modifier Constructor and Description protectedSSLServerSocket()Used only by subclasses.protectedSSLServerSocket(int port)Used only by subclasses.protectedSSLServerSocket(int port, int backlog)Used only by subclasses.protectedSSLServerSocket(int port, int backlog, InetAddress address)Used only by subclasses.
-
Method Summary
Methods Modifier and Type Method and Description abstract String[]getEnabledCipherSuites()Returns the list of cipher suites which are currently enabled for use by newly accepted connections.abstract String[]getEnabledProtocols()Returns the names of the protocols which are currently enabled for use by the newly accepted connections.abstract booleangetEnableSessionCreation()Returns true if new SSL sessions may be established by the sockets which are created from this server socket.abstract booleangetNeedClientAuth()Returns true if client authentication will be required on newlyaccepted server-modeSSLSockets.SSLParametersgetSSLParameters()Returns the SSLParameters in effect for newly accepted connections.abstract String[]getSupportedCipherSuites()Returns the names of the cipher suites which could be enabled for use on an SSL connection.abstract String[]getSupportedProtocols()Returns the names of the protocols which could be enabled for use.abstract booleangetUseClientMode()Returns true if accepted connections will be in SSL client mode.abstract booleangetWantClientAuth()Returns true if client authentication will be requested on newly accepted server-mode connections.abstract voidsetEnabledCipherSuites(String[] suites)Sets the cipher suites enabled for use by accepted connections.abstract voidsetEnabledProtocols(String[] protocols)Controls which particular protocols are enabled for use by accepted connections.abstract voidsetEnableSessionCreation(boolean flag)Controls whether new SSL sessions may be established by the sockets which are created from this server socket.abstract voidsetNeedClientAuth(boolean need)Controls whetheraccepted server-modeSSLSocketswill be initially configured to require client authentication.voidsetSSLParameters(SSLParameters params)Applies SSLParameters to newly accepted connections.abstract voidsetUseClientMode(boolean mode)Controls whether accepted connections are in the (default) SSL server mode, or the SSL client mode.abstract voidsetWantClientAuth(boolean want)Controls whetheraccepted server-modeSSLSocketswill be initially configured to request client authentication.-
Methods inherited from class java.net.ServerSocket
accept, bind, bind, close, getChannel, getInetAddress, getLocalPort, getLocalSocketAddress, getReceiveBufferSize, getReuseAddress, getSoTimeout, implAccept, isBound, isClosed, setPerformancePreferences, setReceiveBufferSize, setReuseAddress, setSocketFactory, setSoTimeout, toString
-
-
-
-
Constructor Detail
-
SSLServerSocket
protected SSLServerSocket() throws IOExceptionUsed only by subclasses.Create an unbound TCP server socket using the default authentication context.
- Throws:
IOException- if an I/O error occurs when creating the socket
-
SSLServerSocket
protected SSLServerSocket(int port) throws IOExceptionUsed only by subclasses.Create a TCP server socket on a port, using the default authentication context. The connection backlog defaults to fifty connections queued up before the system starts to reject new connection requests.
A port number of
0creates a socket on any free port.If there is a security manager, its
checkListenmethod is called with theportargument as its argument to ensure the operation is allowed. This could result in a SecurityException.- Parameters:
port- the port on which to listen- Throws:
IOException- if an I/O error occurs when creating the socketSecurityException- if a security manager exists and itscheckListenmethod doesn't allow the operation.IllegalArgumentException- if the port parameter is outside the specified range of valid port values, which is between 0 and 65535, inclusive.- See Also:
SecurityManager.checkListen(int)
-
SSLServerSocket
protected SSLServerSocket(int port, int backlog) throws IOExceptionUsed only by subclasses.Create a TCP server socket on a port, using the default authentication context and a specified backlog of connections.
A port number of
0creates a socket on any free port.The
backlogargument is the requested maximum number of pending connections on the socket. Its exact semantics are implementation specific. In particular, an implementation may impose a maximum length or may choose to ignore the parameter altogther. The value provided should be greater than0. If it is less than or equal to0, then an implementation specific default will be used.If there is a security manager, its
checkListenmethod is called with theportargument as its argument to ensure the operation is allowed. This could result in a SecurityException.- Parameters:
port- the port on which to listenbacklog- requested maximum length of the queue of incoming connections.- Throws:
IOException- if an I/O error occurs when creating the socketSecurityException- if a security manager exists and itscheckListenmethod doesn't allow the operation.IllegalArgumentException- if the port parameter is outside the specified range of valid port values, which is between 0 and 65535, inclusive.- See Also:
SecurityManager.checkListen(int)
-
SSLServerSocket
protected SSLServerSocket(int port, int backlog, InetAddress address) throws IOExceptionUsed only by subclasses.Create a TCP server socket on a port, using the default authentication context and a specified backlog of connections as well as a particular specified network interface. This constructor is used on multihomed hosts, such as those used for firewalls or as routers, to control through which interface a network service is provided.
If there is a security manager, its
checkListenmethod is called with theportargument as its argument to ensure the operation is allowed. This could result in a SecurityException.A port number of
0creates a socket on any free port.The
backlogargument is the requested maximum number of pending connections on the socket. Its exact semantics are implementation specific. In particular, an implementation may impose a maximum length or may choose to ignore the parameter altogther. The value provided should be greater than0. If it is less than or equal to0, then an implementation specific default will be used.If address is null, it will default accepting connections on any/all local addresses.
- Parameters:
port- the port on which to listenbacklog- requested maximum length of the queue of incoming connections.address- the address of the network interface through which connections will be accepted- Throws:
IOException- if an I/O error occurs when creating the socketSecurityException- if a security manager exists and itscheckListenmethod doesn't allow the operation.IllegalArgumentException- if the port parameter is outside the specified range of valid port values, which is between 0 and 65535, inclusive.- See Also:
SecurityManager.checkListen(int)
-
-
Method Detail
-
getEnabledCipherSuites
public abstract String[] getEnabledCipherSuites()
Returns the list of cipher suites which are currently enabled for use by newly accepted connections.If this list has not been explicitly modified, a system-provided default guarantees a minimum quality of service in all enabled cipher suites.
There are several reasons why an enabled cipher suite might not actually be used. For example: the server socket might not have appropriate private keys available to it or the cipher suite might be anonymous, precluding the use of client authentication, while the server socket has been told to require that sort of authentication.
- Returns:
- an array of cipher suites enabled
- See Also:
getSupportedCipherSuites(),setEnabledCipherSuites(String [])
-
setEnabledCipherSuites
public abstract void setEnabledCipherSuites(String[] suites)
Sets the cipher suites enabled for use by accepted connections.The cipher suites must have been listed by getSupportedCipherSuites() as being supported. Following a successful call to this method, only suites listed in the
suitesparameter are enabled for use.Suites that require authentication information which is not available in this ServerSocket's authentication context will not be used in any case, even if they are enabled.
SSLSockets returned fromaccept()inherit this setting.- Parameters:
suites- Names of all the cipher suites to enable- Throws:
IllegalArgumentException- when one or more of ciphers named by the parameter is not supported, or when the parameter is null.- See Also:
getSupportedCipherSuites(),getEnabledCipherSuites()
-
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
- See Also:
getEnabledCipherSuites(),setEnabledCipherSuites(String [])
-
getSupportedProtocols
public abstract String[] getSupportedProtocols()
Returns the names of the protocols which could be enabled for use.- Returns:
- an array of protocol names supported
- See Also:
getEnabledProtocols(),setEnabledProtocols(String [])
-
getEnabledProtocols
public abstract String[] getEnabledProtocols()
Returns the names of the protocols which are currently enabled for use by the newly accepted connections.- Returns:
- an array of protocol names
- See Also:
getSupportedProtocols(),setEnabledProtocols(String [])
-
setEnabledProtocols
public abstract void setEnabledProtocols(String[] protocols)
Controls which particular protocols are enabled for use by accepted connections.The protocols must have been listed by getSupportedProtocols() as being supported. Following a successful call to this method, only protocols listed in the
protocolsparameter are enabled for use.SSLSockets returned fromaccept()inherit this setting.- Parameters:
protocols- Names of all the protocols to enable.- Throws:
IllegalArgumentException- when one or more of the protocols named by the parameter is not supported or when the protocols parameter is null.- See Also:
getEnabledProtocols(),getSupportedProtocols()
-
setNeedClientAuth
public abstract void setNeedClientAuth(boolean need)
Controls whetheraccepted server-modeSSLSocketswill be initially configured to require client authentication.A socket's client authentication setting is one of the following:
- client authentication required
- client authentication requested
- no client authentication desired
Unlike
setWantClientAuth(boolean), if the accepted socket's option is set and the client chooses not to provide authentication information about itself, the negotiations will stop and the connection will be dropped.Calling this method overrides any previous setting made by this method or
setWantClientAuth(boolean).The initial inherited setting may be overridden by calling
SSLSocket.setNeedClientAuth(boolean)orSSLSocket.setWantClientAuth(boolean).- Parameters:
need- set to true if client authentication is required, or false if no client authentication is desired.- See Also:
getNeedClientAuth(),setWantClientAuth(boolean),getWantClientAuth(),setUseClientMode(boolean)
-
getNeedClientAuth
public abstract boolean getNeedClientAuth()
Returns true if client authentication will be required on newlyaccepted server-modeSSLSockets.The initial inherited setting may be overridden by calling
SSLSocket.setNeedClientAuth(boolean)orSSLSocket.setWantClientAuth(boolean).- Returns:
- true if client authentication is required, or false if no client authentication is desired.
- See Also:
setNeedClientAuth(boolean),setWantClientAuth(boolean),getWantClientAuth(),setUseClientMode(boolean)
-
setWantClientAuth
public abstract void setWantClientAuth(boolean want)
Controls whetheraccepted server-modeSSLSocketswill be initially configured to request client authentication.A socket's client authentication setting is one of the following:
- client authentication required
- client authentication requested
- no client authentication desired
Unlike
setNeedClientAuth(boolean), if the accepted socket's option is set and the client chooses not to provide authentication information about itself, the negotiations will continue.Calling this method overrides any previous setting made by this method or
setNeedClientAuth(boolean).The initial inherited setting may be overridden by calling
SSLSocket.setNeedClientAuth(boolean)orSSLSocket.setWantClientAuth(boolean).- Parameters:
want- set to true if client authentication is requested, or false if no client authentication is desired.- See Also:
getWantClientAuth(),setNeedClientAuth(boolean),getNeedClientAuth(),setUseClientMode(boolean)
-
getWantClientAuth
public abstract boolean getWantClientAuth()
Returns true if client authentication will be requested on newly accepted server-mode connections.The initial inherited setting may be overridden by calling
SSLSocket.setNeedClientAuth(boolean)orSSLSocket.setWantClientAuth(boolean).- Returns:
- true if client authentication is requested, or false if no client authentication is desired.
- See Also:
setWantClientAuth(boolean),setNeedClientAuth(boolean),getNeedClientAuth(),setUseClientMode(boolean)
-
setUseClientMode
public abstract void setUseClientMode(boolean mode)
Controls whether accepted connections are in the (default) SSL server mode, or the SSL client mode.Servers normally authenticate themselves, and clients are not required to do so.
In rare cases, TCP servers need to act in the SSL client mode on newly accepted connections. For example, FTP clients acquire server sockets and listen there for reverse connections from the server. An FTP client would use an SSLServerSocket in "client" mode to accept the reverse connection while the FTP server uses an SSLSocket with "client" mode disabled to initiate the connection. During the resulting handshake, existing SSL sessions may be reused.
SSLSockets returned fromaccept()inherit this setting.- Parameters:
mode- true if newly accepted connections should use SSL client mode.- See Also:
getUseClientMode()
-
getUseClientMode
public abstract boolean getUseClientMode()
Returns true if accepted connections will be in SSL client mode.- Returns:
- true if the connection should use SSL client mode.
- See Also:
setUseClientMode(boolean)
-
setEnableSessionCreation
public abstract void setEnableSessionCreation(boolean flag)
Controls whether new SSL sessions may be established by the sockets which are created from this server socket.SSLSockets returned fromaccept()inherit this setting.- Parameters:
flag- true indicates that sessions may be created; this is the default. false indicates that an existing session must be resumed.- See Also:
getEnableSessionCreation()
-
getEnableSessionCreation
public abstract boolean getEnableSessionCreation()
Returns true if new SSL sessions may be established by the sockets which are created from this server socket.- Returns:
- true indicates that sessions may be created; this is the default. false indicates that an existing session must be resumed
- See Also:
setEnableSessionCreation(boolean)
-
getSSLParameters
public SSLParameters getSSLParameters()
Returns the SSLParameters in effect for newly accepted connections. The ciphersuites and protocols of the returned SSLParameters are always non-null.- Returns:
- the SSLParameters in effect for newly accepted connections
- Since:
- 1.7
- See Also:
setSSLParameters(SSLParameters)
-
setSSLParameters
public void setSSLParameters(SSLParameters params)
Applies SSLParameters to newly accepted connections.This means:
- if
params.getCipherSuites()is non-null,setEnabledCipherSuites()is called with that value - if
params.getProtocols()is non-null,setEnabledProtocols()is called with that value - if
params.getNeedClientAuth()orparams.getWantClientAuth()returntrue,setNeedClientAuth(true)andsetWantClientAuth(true)are called, respectively; otherwisesetWantClientAuth(false)is called.
- Parameters:
params- the parameters- Throws:
IllegalArgumentException- if the setEnabledCipherSuites() or the setEnabledProtocols() call fails- Since:
- 1.7
- See Also:
getSSLParameters()
- if
-
-
Traduction non disponible
Les API Java ne sont pas encore traduites en français sur l'infobrol. Seule la version anglaise est disponible pour l'instant.
Version en cache
15/10/2025 01:50:43 Cette version de la page est en cache (à la date du 15/10/2025 01:50:43) afin d'accélérer le traitement.Vous pouvez activer le mode utilisateur dans le menu en haut pour afficher la version plus récente de la page.
Document créé le 16/09/2006, dernière modification le 04/03/2020
Source du document imprimé : https://www.gaudry.be/java-api-rf-javax/net/ssl/sslserversocket.html
L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.
Références
Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.