X509KeyManager
public interface X509KeyManager
implements KeyManager
javax.net.ssl.X509KeyManager |
Instances of this interface manage which X509 certificate-based key pairs are used to authenticate the local side of a secure socket.
During secure socket negotiations, implentations call methods in this interface to:
- determine the set of aliases that are available for negotiations based on the criteria presented,
- select the best alias based on the criteria presented, and
- obtain the corresponding key material for given aliases.
Note: the X509ExtendedKeyManager should be used in favor of this class.
Summary
Public methods | |
---|---|
abstract String | chooseClientAlias(String[] keyType, Principal[] issuers, Socket socket) Choose an alias to authenticate the client side of a secure socket given the public key type and the list of certificate issuer authorities recognized by the peer (if any). |
abstract String | chooseServerAlias(String keyType, Principal[] issuers, Socket socket) Choose an alias to authenticate the server side of a secure socket given the public key type and the list of certificate issuer authorities recognized by the peer (if any). |
abstract X509Certificate[] | getCertificateChain(String alias) Returns the certificate chain associated with the given alias. |
abstract String[] | getClientAliases(String keyType, Principal[] issuers) Get the matching aliases for authenticating the client side of a secure socket given the public key type and the list of certificate issuer authorities recognized by the peer (if any). |
abstract PrivateKey | getPrivateKey(String alias) Returns the key associated with the given alias. |
abstract String[] | getServerAliases(String keyType, Principal[] issuers) Get the matching aliases for authenticating the server side of a secure socket given the public key type and the list of certificate issuer authorities recognized by the peer (if any). |
Public methods
chooseClientAlias
public abstract String chooseClientAlias (String[] keyType, Principal[] issuers, Socket socket)
Choose an alias to authenticate the client side of a secure socket given the public key type and the list of certificate issuer authorities recognized by the peer (if any).
Parameters | |
---|---|
keyType | String : the key algorithm type name(s), ordered with the most-preferred key type first. |
issuers | Principal : the list of acceptable CA issuer subject names or null if it does not matter which issuers are used. |
socket | Socket : the socket to be used for this connection. This parameter can be null, which indicates that implementations are free to select an alias applicable to any socket. |
Returns | |
---|---|
String | the alias name for the desired key, or null if there are no matches. |
chooseServerAlias
public abstract String chooseServerAlias (String keyType, Principal[] issuers, Socket socket)
Choose an alias to authenticate the server side of a secure socket given the public key type and the list of certificate issuer authorities recognized by the peer (if any).
Parameters | |
---|---|
keyType | String : the key algorithm type name. |
issuers | Principal : the list of acceptable CA issuer subject names or null if it does not matter which issuers are used. |
socket | Socket : the socket to be used for this connection. This parameter can be null, which indicates that implementations are free to select an alias applicable to any socket. |
Returns | |
---|---|
String | the alias name for the desired key, or null if there are no matches. |
getCertificateChain
public abstract X509Certificate[] getCertificateChain (String alias)
Returns the certificate chain associated with the given alias.
Parameters | |
---|---|
alias | String : the alias name |
Returns | |
---|---|
X509Certificate[] | the certificate chain (ordered with the user's certificate first and the root certificate authority last), or null if the alias can't be found. |
getClientAliases
public abstract String[] getClientAliases (String keyType, Principal[] issuers)
Get the matching aliases for authenticating the client side of a secure socket given the public key type and the list of certificate issuer authorities recognized by the peer (if any).
Parameters | |
---|---|
keyType | String : the key algorithm type name |
issuers | Principal : the list of acceptable CA issuer subject names, or null if it does not matter which issuers are used. |
Returns | |
---|---|
String[] | an array of the matching alias names, or null if there were no matches. |
getPrivateKey
public abstract PrivateKey getPrivateKey (String alias)
Returns the key associated with the given alias.
Parameters | |
---|---|
alias | String : the alias name |
Returns | |
---|---|
PrivateKey | the requested key, or null if the alias can't be found. |
getServerAliases
public abstract String[] getServerAliases (String keyType, Principal[] issuers)
Get the matching aliases for authenticating the server side of a secure socket given the public key type and the list of certificate issuer authorities recognized by the peer (if any).
Parameters | |
---|---|
keyType | String : the key algorithm type name |
issuers | Principal : the list of acceptable CA issuer subject names or null if it does not matter which issuers are used. |
Returns | |
---|---|
String[] | an array of the matching alias names, or null if there were no matches. |