Class FormAuthenticator
java.lang.Object
org.apache.catalina.util.LifecycleBase
org.apache.catalina.util.LifecycleMBeanBase
org.apache.catalina.valves.ValveBase
org.apache.catalina.authenticator.AuthenticatorBase
org.apache.catalina.authenticator.FormAuthenticator
- All Implemented Interfaces:
- RegistrationListener,- MBeanRegistration,- Authenticator,- Contained,- JmxEnabled,- Lifecycle,- Valve
An Authenticator and Valve implementation of FORM BASED Authentication, as described in the Servlet API
 Specification.
- Author:
- Craig R. McClanahan, Remy Maucherat
- 
Nested Class SummaryNested classes/interfaces inherited from class org.apache.catalina.authenticator.AuthenticatorBaseAuthenticatorBase.AllowCorsPreflightNested classes/interfaces inherited from interface org.apache.catalina.LifecycleLifecycle.SingleUse
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected intIf the authentication process creates a session, this is the maximum session timeout (in seconds) during the authentication process.protected StringCharacter encoding to use to read the username and password parameters from the request.protected StringLanding page to use if a user tries to access the login page directly or if the session times out during login.Fields inherited from class org.apache.catalina.authenticator.AuthenticatorBasealwaysUseSession, AUTH_HEADER_NAME, cache, changeSessionIdOnAuthentication, context, disableProxyCaching, jaspicCallbackHandlerClass, REALM_NAME, securePagesWithPragma, secureRandomAlgorithm, secureRandomClass, secureRandomProvider, sendAuthInfoResponseHeaders, sessionIdGenerator, sm, ssoFields inherited from class org.apache.catalina.valves.ValveBaseasyncSupported, container, containerLog, nextFields inherited from interface org.apache.catalina.LifecycleAFTER_DESTROY_EVENT, AFTER_INIT_EVENT, AFTER_START_EVENT, AFTER_STOP_EVENT, BEFORE_DESTROY_EVENT, BEFORE_INIT_EVENT, BEFORE_START_EVENT, BEFORE_STOP_EVENT, CONFIGURE_START_EVENT, CONFIGURE_STOP_EVENT, PERIODIC_EVENT, START_EVENT, STOP_EVENT
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected booleandoAuthenticate(Request request, HttpServletResponse response) Authenticate the user making this request, based on the specified login configuration.protected voidforwardToErrorPage(Request request, HttpServletResponse response, LoginConfig config) Called to forward to the error pageprotected voidforwardToLoginPage(Request request, HttpServletResponse response, LoginConfig config) Called to forward to the login pageintReturns the maximum session timeout to be used during authentication if the authentication process creates a session.protected StringReturn the authentication method, which is vendor-specific and not defined by HttpServletRequest.Return the character encoding to use to read the user name and password.Return the landing page to use when FORM auth is mis-used.protected booleanisContinuationRequired(Request request) Does this authenticator require thatAuthenticatorBase.authenticate(Request, HttpServletResponse)is called to continue an authentication process that started in a previous request?protected booleanmatchRequest(Request request) Does this request match the saved one (so that it must be the redirect we signaled after successful authentication?protected voidregister(Request request, HttpServletResponse response, Principal principal, String authType, String username, String password, boolean alwaysUseSession, boolean cache) Register an authenticated Principal and authentication type in our request, in the current session (if there is one), and with our SingleSignOn valve, if there is one.protected booleanrestoreRequest(Request request, Session session) Restore the original request from information stored in our session.protected StringsavedRequestURL(Session session) Return the request URI (with the corresponding query string, if any) from the saved request so that we can redirect to it.protected voidsaveRequest(Request request, Session session) Save the original request information into our session.voidsetAuthenticationSessionTimeout(int authenticationSessionTimeout) Configures the maximum session timeout to be used during authentication if the authentication process creates a session.voidsetCharacterEncoding(String encoding) Set the character encoding to be used to read the user name and password.voidsetLandingPage(String landingPage) Set the landing page to use when the FORM auth is mis-used.Methods inherited from class org.apache.catalina.authenticator.AuthenticatorBaseallowCorsPreflightBypass, associate, authenticate, changeSessionID, checkForCachedAuthentication, doLogin, getAllowCorsPreflight, getAlwaysUseSession, getCache, getChangeSessionIdOnAuthentication, getContainer, getDisableProxyCaching, getJaspicCallbackHandlerClass, getRealmName, getSecurePagesWithPragma, getSecureRandomAlgorithm, getSecureRandomClass, getSecureRandomProvider, invoke, isPreemptiveAuthPossible, isSendAuthInfoResponseHeaders, login, logout, notify, reauthenticateFromSSO, register, setAllowCorsPreflight, setAlwaysUseSession, setCache, setChangeSessionIdOnAuthentication, setContainer, setDisableProxyCaching, setJaspicCallbackHandlerClass, setSecurePagesWithPragma, setSecureRandomAlgorithm, setSecureRandomClass, setSecureRandomProvider, setSendAuthInfoResponseHeaders, startInternal, stopInternalMethods inherited from class org.apache.catalina.valves.ValveBasebackgroundProcess, getDomainInternal, getNext, getObjectNameKeyProperties, initInternal, isAsyncSupported, setAsyncSupported, setNext, toStringMethods inherited from class org.apache.catalina.util.LifecycleMBeanBasedestroyInternal, getDomain, getObjectName, postDeregister, postRegister, preDeregister, preRegister, register, setDomain, unregister, unregisterMethods inherited from class org.apache.catalina.util.LifecycleBaseaddLifecycleListener, destroy, findLifecycleListeners, fireLifecycleEvent, getState, getStateName, getThrowOnFailure, init, removeLifecycleListener, setState, setState, setThrowOnFailure, start, stop
- 
Field Details- 
characterEncodingCharacter encoding to use to read the username and password parameters from the request. If not set, the encoding of the request body will be used.
- 
landingPageLanding page to use if a user tries to access the login page directly or if the session times out during login. If not set, error responses will be sent instead.
- 
authenticationSessionTimeoutprotected int authenticationSessionTimeoutIf the authentication process creates a session, this is the maximum session timeout (in seconds) during the authentication process. Once authentication is complete, the default session timeout will apply. Sessions that exist before the authentication process starts will retain their original session timeout throughout.
 
- 
- 
Constructor Details- 
FormAuthenticatorpublic FormAuthenticator()
 
- 
- 
Method Details- 
getCharacterEncodingReturn the character encoding to use to read the user name and password.- Returns:
- The name of the character encoding
 
- 
setCharacterEncodingSet the character encoding to be used to read the user name and password.- Parameters:
- encoding- The name of the encoding to use
 
- 
getLandingPageReturn the landing page to use when FORM auth is mis-used.- Returns:
- The path to the landing page relative to the web application root
 
- 
setLandingPageSet the landing page to use when the FORM auth is mis-used.- Parameters:
- landingPage- The path to the landing page relative to the web application root
 
- 
getAuthenticationSessionTimeoutpublic int getAuthenticationSessionTimeout()Returns the maximum session timeout to be used during authentication if the authentication process creates a session.- Returns:
- the maximum session timeout to be used during authentication if the authentication process creates a session
 
- 
setAuthenticationSessionTimeoutpublic void setAuthenticationSessionTimeout(int authenticationSessionTimeout) Configures the maximum session timeout to be used during authentication if the authentication process creates a session.- Parameters:
- authenticationSessionTimeout- The maximum session timeout to use duriing authentication if the authentication process creates a session
 
- 
doAuthenticateAuthenticate the user making this request, based on the specified login configuration. Returntrueif any specified constraint has been satisfied, orfalseif we have created a response challenge already.- Specified by:
- doAuthenticatein class- AuthenticatorBase
- Parameters:
- request- Request we are processing
- response- Response we are creating
- Returns:
- trueif the the user was authenticated, otherwise- false, in which case an authentication challenge will have been written to the response
- Throws:
- IOException- if an input/output error occurs
 
- 
isContinuationRequiredDescription copied from class:AuthenticatorBaseDoes this authenticator require thatAuthenticatorBase.authenticate(Request, HttpServletResponse)is called to continue an authentication process that started in a previous request?- Overrides:
- isContinuationRequiredin class- AuthenticatorBase
- Parameters:
- request- The request currently being processed
- Returns:
- trueif authenticate() must be called, otherwise- false
 
- 
getAuthMethodDescription copied from class:AuthenticatorBaseReturn the authentication method, which is vendor-specific and not defined by HttpServletRequest.- Specified by:
- getAuthMethodin class- AuthenticatorBase
- Returns:
- the authentication method, which is vendor-specific and not defined by HttpServletRequest.
 
- 
registerprotected void register(Request request, HttpServletResponse response, Principal principal, String authType, String username, String password, boolean alwaysUseSession, boolean cache) Description copied from class:AuthenticatorBaseRegister an authenticated Principal and authentication type in our request, in the current session (if there is one), and with our SingleSignOn valve, if there is one. Set the appropriate cookie to be returned.- Overrides:
- registerin class- AuthenticatorBase
- Parameters:
- request- The servlet request we are processing
- response- The servlet response we are generating
- principal- The authenticated Principal to be registered
- authType- The authentication type to be registered
- username- Username used to authenticate (if any)
- password- Password used to authenticate (if any)
- alwaysUseSession- Should a session always be used once a user is authenticated?
- cache- Should we cache authenticated Principals if the request is part of an HTTP session?
 
- 
forwardToLoginPageprotected void forwardToLoginPage(Request request, HttpServletResponse response, LoginConfig config) throws IOException Called to forward to the login page- Parameters:
- request- Request we are processing
- response- Response we are populating
- config- Login configuration describing how authentication should be performed
- Throws:
- IOException- If the forward to the login page fails and the call to- HttpServletResponse.sendError(int, String)throws an- IOException
 
- 
forwardToErrorPageprotected void forwardToErrorPage(Request request, HttpServletResponse response, LoginConfig config) throws IOException Called to forward to the error page- Parameters:
- request- Request we are processing
- response- Response we are populating
- config- Login configuration describing how authentication should be performed
- Throws:
- IOException- If the forward to the error page fails and the call to- HttpServletResponse.sendError(int, String)throws an- IOException
 
- 
matchRequestDoes this request match the saved one (so that it must be the redirect we signaled after successful authentication?- Parameters:
- request- The request to be verified
- Returns:
- trueif the requests matched the saved one
 
- 
restoreRequestRestore the original request from information stored in our session. If the original request is no longer present (because the session timed out), returnfalse; otherwise, returntrue.- Parameters:
- request- The request to be restored
- session- The session containing the saved information
- Returns:
- trueif the request was successfully restored
- Throws:
- IOException- if an IO error occurred during the process
 
- 
saveRequestSave the original request information into our session.- Parameters:
- request- The request to be saved
- session- The session to contain the saved information
- Throws:
- IOException- if an IO error occurred during the process
 
- 
savedRequestURLReturn the request URI (with the corresponding query string, if any) from the saved request so that we can redirect to it.- Parameters:
- session- Our current session
- Returns:
- the original request URL
 
 
-