javax.net.ssl

Class SSLServerSocket

  • All Implemented Interfaces:
    Closeable, AutoCloseable

    public abstract class SSLServerSocket
    extends ServerSocket
    This class extends ServerSockets 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 of SSLServerSockets is to create SSLSockets by accepting connections.

    SSLServerSockets contain several pieces of state data which are inherited by the SSLSocket at 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 created SSLSocket can be overriden by calling the appropriate methods.

    Since:
    1.4
    See Also:
    ServerSocket, SSLSocket
    • Constructor Detail
      • SSLServerSocket
        protected SSLServerSocket()
                           throws IOException
        Used 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 IOException
        Used 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 0 creates a socket on any free port.

        If there is a security manager, its checkListen method is called with the port argument 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 socket
        SecurityException - if a security manager exists and its checkListen method 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 IOException
        Used 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 0 creates a socket on any free port.

        The backlog argument 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 than 0. If it is less than or equal to 0, then an implementation specific default will be used.

        If there is a security manager, its checkListen method is called with the port argument as its argument to ensure the operation is allowed. This could result in a SecurityException.

        Parameters:
        port - the port on which to listen
        backlog - requested maximum length of the queue of incoming connections.
        Throws:
        IOException - if an I/O error occurs when creating the socket
        SecurityException - if a security manager exists and its checkListen method 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 IOException
        Used 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 checkListen method is called with the port argument as its argument to ensure the operation is allowed. This could result in a SecurityException.

        A port number of 0 creates a socket on any free port.

        The backlog argument 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 than 0. If it is less than or equal to 0, 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 listen
        backlog - 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 socket
        SecurityException - if a security manager exists and its checkListen method 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 suites parameter 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 from accept() 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 [])
      • 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 protocols parameter are enabled for use.

        SSLSockets returned from accept() 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()
      • 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 from accept() 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 from accept() 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() or params.getWantClientAuth() return true, setNeedClientAuth(true) and setWantClientAuth(true) are called, respectively; otherwise setWantClientAuth(false) is called.
        Parameters:
        params - the parameters
        Throws:
        IllegalArgumentException - if the setEnabledCipherSuites() or the setEnabledProtocols() call fails
        Since:
        1.7
        See Also:
        getSSLParameters()

Nederlandse vertaling

U hebt gevraagd om deze site in het Nederlands te bezoeken. Voor nu wordt alleen de interface vertaald, maar nog niet alle inhoud.

Als je me wilt helpen met vertalingen, is je bijdrage welkom. Het enige dat u hoeft te doen, is u op de site registreren en mij een bericht sturen waarin u wordt gevraagd om u toe te voegen aan de groep vertalers, zodat u de gewenste pagina's kunt vertalen. Een link onderaan elke vertaalde pagina geeft aan dat u de vertaler bent en heeft een link naar uw profiel.

Bij voorbaat dank.

Document heeft de 11/06/2005 gemaakt, de laatste keer de 04/03/2020 gewijzigd
Bron van het afgedrukte document:https://www.gaudry.be/nl/java-api-rf-javax/net/ssl/SSLServerSocket.html

De infobrol is een persoonlijke site waarvan de inhoud uitsluitend mijn verantwoordelijkheid is. De tekst is beschikbaar onder CreativeCommons-licentie (BY-NC-SA). Meer info op de gebruiksvoorwaarden en de auteur.

Referenties

  1. Bekijk - html-document Taal van het document:fr Manuel PHP : https://docs.oracle.com

Deze verwijzingen en links verwijzen naar documenten die geraadpleegd zijn tijdens het schrijven van deze pagina, of die aanvullende informatie kunnen geven, maar de auteurs van deze bronnen kunnen niet verantwoordelijk worden gehouden voor de inhoud van deze pagina.
De auteur Deze site is als enige verantwoordelijk voor de manier waarop de verschillende concepten, en de vrijheden die met de referentiewerken worden genomen, hier worden gepresenteerd. Vergeet niet dat u meerdere broninformatie moet doorgeven om het risico op fouten te verkleinen.

Inhoudsopgave Haut