Class SSLContextSpi
public abstract class SSLContextSpi extends Object
SSLContext class. All the abstract methods in this class must be implemented by each cryptographic service provider who wishes to supply the implementation of a particular SSL context.
- Since:
- 1.4
- See Also:
Constructor Summary
| Constructor | Description | 
|---|---|
| SSLContextSpi() | Constructor for subclasses to call. | 
Method Summary
| Modifier and Type | Method | Description | 
|---|---|---|
| protected abstract SSLEngine | engineCreateSSLEngine() | Creates a new  SSLEngineusing this context. | 
| protected abstract SSLEngine | engineCreateSSLEngine | Creates a  SSLEngineusing this context. | 
| protected abstract SSLSessionContext | engineGetClientSessionContext() | Returns a client  SSLSessionContextobject for this context. | 
| protected SSLParameters | engineGetDefaultSSLParameters() | Returns a copy of the SSLParameters indicating the default settings for this SSL context. | 
| protected abstract SSLSessionContext | engineGetServerSessionContext() | Returns a server  SSLSessionContextobject for this context. | 
| protected abstract SSLServerSocketFactory | engineGetServerSocketFactory() | Returns a  ServerSocketFactoryobject for this context. | 
| protected abstract SSLSocketFactory | engineGetSocketFactory() | Returns a  SocketFactoryobject for this context. | 
| protected SSLParameters | engineGetSupportedSSLParameters() | Returns a copy of the SSLParameters indicating the maximum supported settings for this SSL context. | 
| protected abstract void | engineInit | Initializes this context. | 
Constructor Details
SSLContextSpi
public SSLContextSpi()
Method Details
engineInit
protected abstract void engineInit(KeyManager[] km, TrustManager[] tm, SecureRandom sr) throws KeyManagementException
- Parameters:
- 
km- the sources of authentication keys
- 
tm- the sources of peer authentication trust decisions
- 
sr- the source of randomness
- Throws:
- 
KeyManagementException- if this operation fails
- See Also:
engineGetSocketFactory
protected abstract SSLSocketFactory engineGetSocketFactory()
SocketFactory object for this context.- Returns:
- the SocketFactoryobject
- Throws:
- 
UnsupportedOperationException- if the underlying provider does not implement the operation.
- 
IllegalStateException- if the SSLContextImpl requires initialization and theengineInit()has not been called
- See Also:
engineGetServerSocketFactory
protected abstract SSLServerSocketFactory engineGetServerSocketFactory()
ServerSocketFactory object for this context.- Returns:
- the ServerSocketFactoryobject
- Throws:
- 
UnsupportedOperationException- if the underlying provider does not implement the operation.
- 
IllegalStateException- if the SSLContextImpl requires initialization and theengineInit()has not been called
- See Also:
engineCreateSSLEngine
protected abstract SSLEngine engineCreateSSLEngine()
SSLEngine using this context.  Applications using this factory method are providing no hints for an internal session reuse strategy. If hints are desired, engineCreateSSLEngine(String, int) should be used instead. 
Some cipher suites (such as Kerberos) require remote hostname information, in which case this factory method should not be used.
- Implementation Note:
- It is provider-specific if the returned SSLEngine uses client or server mode by default for the (D)TLS connection. The JDK SunJSSE provider implementation uses server mode by default. However, it is recommended to always set the desired mode explicitly by calling SSLEngine.setUseClientMode()before invoking other methods of the SSLEngine.
- Returns:
- the SSLEngineObject
- Throws:
- 
IllegalStateException- if the SSLContextImpl requires initialization and theengineInit()has not been called
- Since:
- 1.5
- See Also:
engineCreateSSLEngine
protected abstract SSLEngine engineCreateSSLEngine(String host, int port)
SSLEngine using this context. Applications using this factory method are providing hints for an internal session reuse strategy.
Some cipher suites (such as Kerberos) require remote hostname information, in which case peerHost needs to be specified.
- Implementation Note:
- It is provider-specific if the returned SSLEngine uses client or server mode by default for the (D)TLS connection. The JDK SunJSSE provider implementation uses server mode by default. However, it is recommended to always set the desired mode explicitly by calling SSLEngine.setUseClientMode()before invoking other methods of the SSLEngine.
- Parameters:
- 
host- the non-authoritative name of the host
- 
port- the non-authoritative port
- Returns:
- the SSLEngineObject
- Throws:
- 
IllegalStateException- if the SSLContextImpl requires initialization and theengineInit()has not been called
- Since:
- 1.5
- See Also:
engineGetServerSessionContext
protected abstract SSLSessionContext engineGetServerSessionContext()
SSLSessionContext object for this context.- Returns:
- the SSLSessionContextobject
- See Also:
engineGetClientSessionContext
protected abstract SSLSessionContext engineGetClientSessionContext()
SSLSessionContext object for this context.- Returns:
- the SSLSessionContextobject
- See Also:
engineGetDefaultSSLParameters
protected SSLParameters engineGetDefaultSSLParameters()
The parameters will always have the ciphersuite and protocols arrays set to non-null values.
The default implementation obtains the parameters from an SSLSocket created by calling the SocketFactory.createSocket() method of this context's SocketFactory.
- Returns:
- a copy of the SSLParameters object with the default settings
- Throws:
- 
UnsupportedOperationException- if the default SSL parameters could not be obtained.
- Since:
- 1.6
engineGetSupportedSSLParameters
protected SSLParameters engineGetSupportedSSLParameters()
The parameters will always have the ciphersuite and protocols arrays set to non-null values.
The default implementation obtains the parameters from an SSLSocket created by calling the SocketFactory.createSocket() method of this context's SocketFactory.
- Returns:
- a copy of the SSLParameters object with the maximum supported settings
- Throws:
- 
UnsupportedOperationException- if the supported SSL parameters could not be obtained.
- Since:
- 1.6
    © 1993, 2021, 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.
    https://docs.oracle.com/en/java/javase/17/docs/api/java.base/javax/net/ssl/SSLContextSpi.html