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. |