Package org.apache.catalina.realm
Class JAASCallbackHandler
- java.lang.Object
- 
- org.apache.catalina.realm.JAASCallbackHandler
 
- 
- All Implemented Interfaces:
- CallbackHandler
 
 public class JAASCallbackHandler extends Object implements CallbackHandler Implementation of the JAAS CallbackHandlerinterface, used to negotiate delivery of the username and credentials that were specified to our constructor. No interaction with the user is required (or possible).This CallbackHandlerwill pre-digest the supplied password, if required by the<Realm>element inserver.xml.At present, JAASCallbackHandlerknows how to handle callbacks of typejavax.security.auth.callback.NameCallbackandjavax.security.auth.callback.PasswordCallback.- Author:
- Craig R. McClanahan, Andrew R. Jaquith
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected StringauthMethodThe authentication method to be used.protected StringcnonceClient generated nonce.protected Stringmd5a2Second MD5 digest.protected StringncNonce count.protected StringnonceServer generated nonce.protected StringpasswordThe password to be authenticated with.protected StringqopQuality of protection applied to the message.protected JAASRealmrealmThe associatedJAASRealminstance.protected StringrealmNameRealm name.protected static StringManagersmThe string manager for this package.protected StringusernameThe username to be authenticated with.
 - 
Constructor SummaryConstructors Constructor Description JAASCallbackHandler(JAASRealm realm, String username, String password)Construct a callback handler configured with the specified values.JAASCallbackHandler(JAASRealm realm, String username, String password, String nonce, String nc, String cnonce, String qop, String realmName, String md5a2, String authMethod)Construct a callback handler for DIGEST authentication.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidhandle(Callback[] callbacks)Retrieve the information requested in the providedCallbacks.
 
- 
- 
- 
Field Detail- 
smprotected static final StringManager sm The string manager for this package.
 - 
passwordprotected final String password The password to be authenticated with.
 - 
realmprotected final JAASRealm realm The associatedJAASRealminstance.
 - 
usernameprotected final String username The username to be authenticated with.
 - 
nonceprotected final String nonce Server generated nonce.
 - 
ncprotected final String nc Nonce count.
 - 
cnonceprotected final String cnonce Client generated nonce.
 - 
qopprotected final String qop Quality of protection applied to the message.
 - 
realmNameprotected final String realmName Realm name.
 - 
md5a2protected final String md5a2 Second MD5 digest.
 - 
authMethodprotected final String authMethod The authentication method to be used. If null, assume BASIC/FORM.
 
- 
 - 
Constructor Detail- 
JAASCallbackHandlerpublic JAASCallbackHandler(JAASRealm realm, String username, String password) Construct a callback handler configured with the specified values. Note that if theJAASRealminstance specifies digested passwords, thepasswordparameter will be pre-digested here.- Parameters:
- realm- Our associated JAASRealm instance
- username- Username to be authenticated with
- password- Password to be authenticated with
 
 - 
JAASCallbackHandlerpublic JAASCallbackHandler(JAASRealm realm, String username, String password, String nonce, String nc, String cnonce, String qop, String realmName, String md5a2, String authMethod) Construct a callback handler for DIGEST authentication.- Parameters:
- realm- Our associated JAASRealm instance
- username- Username to be authenticated with
- password- Password to be authenticated with
- nonce- Server generated nonce
- nc- Nonce count
- cnonce- Client generated nonce
- qop- Quality of protection applied to the message
- realmName- Realm name
- md5a2- Second MD5 digest used to calculate the digest MD5(Method + ":" + uri)
- authMethod- The authentication method in use
 
 
- 
 - 
Method Detail- 
handlepublic void handle(Callback[] callbacks) throws IOException, UnsupportedCallbackException Retrieve the information requested in the providedCallbacks. This implementation only recognizesNameCallback,PasswordCallbackandTextInputCallback.TextInputCallbackis used to pass the various additional parameters required for DIGEST authentication.- Specified by:
- handlein interface- CallbackHandler
- Parameters:
- callbacks- The set of- Callbacks to be processed
- Throws:
- IOException- if an input/output error occurs
- UnsupportedCallbackException- if the login method requests an unsupported callback type
 
 
- 
 
-