Relocate common filter authentication functionality to an abstract parent, and update JavaDocs accordingly.
This commit is contained in:
parent
96fa2a5a75
commit
1cf2b333bd
|
@ -17,7 +17,7 @@ package net.sf.acegisecurity.intercept.web;
|
||||||
|
|
||||||
import net.sf.acegisecurity.AccessDeniedException;
|
import net.sf.acegisecurity.AccessDeniedException;
|
||||||
import net.sf.acegisecurity.AuthenticationException;
|
import net.sf.acegisecurity.AuthenticationException;
|
||||||
import net.sf.acegisecurity.ui.webapp.AuthenticationProcessingFilter;
|
import net.sf.acegisecurity.ui.AbstractProcessingFilter;
|
||||||
|
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
|
@ -45,8 +45,8 @@ import javax.servlet.http.HttpServletResponse;
|
||||||
* </p>
|
* </p>
|
||||||
*
|
*
|
||||||
* <p>
|
* <p>
|
||||||
* If a {@link AuthenticationException} is detected, the filter will redirect
|
* If a {@link AuthenticationException} is detected, the filter will launch the
|
||||||
* to the <code>loginFormUrl</code>. This allows common handling of
|
* <code>authenticationEntryPoint</code>. This allows common handling of
|
||||||
* authentication failures originating from any subclass of {@link
|
* authentication failures originating from any subclass of {@link
|
||||||
* net.sf.acegisecurity.intercept.AbstractSecurityInterceptor}.
|
* net.sf.acegisecurity.intercept.AbstractSecurityInterceptor}.
|
||||||
* </p>
|
* </p>
|
||||||
|
@ -156,7 +156,7 @@ public class SecurityEnforcementFilter implements Filter, InitializingBean {
|
||||||
+ fi.getRequestUrl());
|
+ fi.getRequestUrl());
|
||||||
}
|
}
|
||||||
|
|
||||||
((HttpServletRequest) request).getSession().setAttribute(AuthenticationProcessingFilter.ACEGI_SECURITY_TARGET_URL_KEY,
|
((HttpServletRequest) request).getSession().setAttribute(AbstractProcessingFilter.ACEGI_SECURITY_TARGET_URL_KEY,
|
||||||
fi.getRequestUrl());
|
fi.getRequestUrl());
|
||||||
authenticationEntryPoint.commence(request, response);
|
authenticationEntryPoint.commence(request, response);
|
||||||
} catch (AccessDeniedException accessDenied) {
|
} catch (AccessDeniedException accessDenied) {
|
||||||
|
|
|
@ -0,0 +1,259 @@
|
||||||
|
/* Copyright 2004 Acegi Technology Pty Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package net.sf.acegisecurity.ui;
|
||||||
|
|
||||||
|
import net.sf.acegisecurity.Authentication;
|
||||||
|
import net.sf.acegisecurity.AuthenticationException;
|
||||||
|
import net.sf.acegisecurity.AuthenticationManager;
|
||||||
|
import net.sf.acegisecurity.ui.webapp.HttpSessionIntegrationFilter;
|
||||||
|
|
||||||
|
import org.apache.commons.logging.Log;
|
||||||
|
import org.apache.commons.logging.LogFactory;
|
||||||
|
|
||||||
|
import org.springframework.beans.factory.InitializingBean;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import javax.servlet.Filter;
|
||||||
|
import javax.servlet.FilterChain;
|
||||||
|
import javax.servlet.ServletException;
|
||||||
|
import javax.servlet.ServletRequest;
|
||||||
|
import javax.servlet.ServletResponse;
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Abstract processor of HTTP-based authentication requests, which places the
|
||||||
|
* resulting <code>Authentication</code> object into the
|
||||||
|
* <code>HttpSession</code>.
|
||||||
|
*
|
||||||
|
* <p>
|
||||||
|
* This filter is responsible for processing authentication requests. If
|
||||||
|
* authentication is successful, the resulting {@link Authentication} object
|
||||||
|
* will be placed into the <code>HttpSession</code> with the attribute defined
|
||||||
|
* by {@link HttpSessionIntegrationFilter#ACEGI_SECURITY_AUTHENTICATION_KEY}.
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* <p>
|
||||||
|
* If authentication fails, the <code>AuthenticationException</code> will be
|
||||||
|
* placed into the <code>HttpSession</code> with the attribute defined by
|
||||||
|
* {@link #ACEGI_SECURITY_LAST_EXCEPTION_KEY}.
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* <p>
|
||||||
|
* To use this filter, it is necessary to specify the following properties:
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* <ul>
|
||||||
|
* <li>
|
||||||
|
* <code>defaultTargetUrl</code> indicates the URL that should be used for
|
||||||
|
* redirection if the <code>HttpSession</code> attribute named {@link
|
||||||
|
* #ACEGI_SECURITY_TARGET_URL_KEY} does not indicate the target URL once
|
||||||
|
* authentication is completed successfully. eg: <code>/</code>.
|
||||||
|
* </li>
|
||||||
|
* <li>
|
||||||
|
* <code>authenticationFailureUrl</code> indicates the URL that should be used
|
||||||
|
* for redirection if the authentication request fails. eg:
|
||||||
|
* <code>/login.jsp?login_error=1</code>.
|
||||||
|
* </li>
|
||||||
|
* <li>
|
||||||
|
* <code>filterProcessesUrl</code> indicates the URL that this filter will
|
||||||
|
* respond to. This parameter varies by subclass.
|
||||||
|
* </li>
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @author Ben Alex
|
||||||
|
* @version $Id$
|
||||||
|
*/
|
||||||
|
public abstract class AbstractProcessingFilter implements Filter,
|
||||||
|
InitializingBean {
|
||||||
|
//~ Static fields/initializers =============================================
|
||||||
|
|
||||||
|
public static final String ACEGI_SECURITY_TARGET_URL_KEY = "ACEGI_SECURITY_TARGET_URL";
|
||||||
|
public static final String ACEGI_SECURITY_LAST_EXCEPTION_KEY = "ACEGI_SECURITY_LAST_EXCEPTION";
|
||||||
|
protected static final Log logger = LogFactory.getLog(AbstractProcessingFilter.class);
|
||||||
|
|
||||||
|
//~ Instance fields ========================================================
|
||||||
|
|
||||||
|
private AuthenticationManager authenticationManager;
|
||||||
|
|
||||||
|
/** Where to redirect the browser to if authentication fails */
|
||||||
|
private String authenticationFailureUrl;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Where to redirect the browser to if authentication is successful but
|
||||||
|
* ACEGI_SECURITY_TARGET_URL_KEY is <code>null</code>
|
||||||
|
*/
|
||||||
|
private String defaultTargetUrl;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The URL destination that this filter intercepts and processes (usually
|
||||||
|
* something like <code>/j_acegi_security_check</code>)
|
||||||
|
*/
|
||||||
|
private String filterProcessesUrl = getDefaultFilterProcessesUrl();
|
||||||
|
|
||||||
|
//~ Methods ================================================================
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Specifies the default <code>filterProcessesUrl</code> for the
|
||||||
|
* implementation.
|
||||||
|
*
|
||||||
|
* @return the default <code>filterProcessesUrl</code>
|
||||||
|
*/
|
||||||
|
public abstract String getDefaultFilterProcessesUrl();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Performs actual authentication.
|
||||||
|
*
|
||||||
|
* @param request from which to extract parameters and perform the
|
||||||
|
* authentication
|
||||||
|
*
|
||||||
|
* @return the authenticated user
|
||||||
|
*
|
||||||
|
* @throws AuthenticationException if authentication fails
|
||||||
|
*/
|
||||||
|
public abstract Authentication attemptAuthentication(
|
||||||
|
HttpServletRequest request) throws AuthenticationException;
|
||||||
|
|
||||||
|
public void setAuthenticationFailureUrl(String authenticationFailureUrl) {
|
||||||
|
this.authenticationFailureUrl = authenticationFailureUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getAuthenticationFailureUrl() {
|
||||||
|
return authenticationFailureUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setAuthenticationManager(
|
||||||
|
AuthenticationManager authenticationManager) {
|
||||||
|
this.authenticationManager = authenticationManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
public AuthenticationManager getAuthenticationManager() {
|
||||||
|
return authenticationManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDefaultTargetUrl(String defaultTargetUrl) {
|
||||||
|
this.defaultTargetUrl = defaultTargetUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getDefaultTargetUrl() {
|
||||||
|
return defaultTargetUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setFilterProcessesUrl(String filterProcessesUrl) {
|
||||||
|
this.filterProcessesUrl = filterProcessesUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getFilterProcessesUrl() {
|
||||||
|
return filterProcessesUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void afterPropertiesSet() throws Exception {
|
||||||
|
if ((filterProcessesUrl == null) || "".equals(filterProcessesUrl)) {
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
"filterProcessesUrl must be specified");
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((defaultTargetUrl == null) || "".equals(defaultTargetUrl)) {
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
"defaultTargetUrl must be specified");
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((authenticationFailureUrl == null)
|
||||||
|
|| "".equals(authenticationFailureUrl)) {
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
"authenticationFailureUrl must be specified");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (authenticationManager == null) {
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
"authenticationManager must be specified");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void destroy() {}
|
||||||
|
|
||||||
|
public void doFilter(ServletRequest request, ServletResponse response,
|
||||||
|
FilterChain chain) throws IOException, ServletException {
|
||||||
|
if (!(request instanceof HttpServletRequest)) {
|
||||||
|
throw new ServletException("Can only process HttpServletRequest");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(response instanceof HttpServletResponse)) {
|
||||||
|
throw new ServletException("Can only process HttpServletResponse");
|
||||||
|
}
|
||||||
|
|
||||||
|
HttpServletRequest httpRequest = (HttpServletRequest) request;
|
||||||
|
HttpServletResponse httpResponse = (HttpServletResponse) response;
|
||||||
|
|
||||||
|
if (filterProcessesUrl.equals(httpRequest.getServletPath())) {
|
||||||
|
if (logger.isDebugEnabled()) {
|
||||||
|
logger.debug("Request is to process authentication");
|
||||||
|
}
|
||||||
|
|
||||||
|
Authentication authResult;
|
||||||
|
|
||||||
|
try {
|
||||||
|
authResult = attemptAuthentication(httpRequest);
|
||||||
|
} catch (AuthenticationException failed) {
|
||||||
|
// Authentication failed
|
||||||
|
if (logger.isDebugEnabled()) {
|
||||||
|
logger.debug("Authentication request failed: "
|
||||||
|
+ failed.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
httpRequest.getSession().setAttribute(ACEGI_SECURITY_LAST_EXCEPTION_KEY,
|
||||||
|
failed);
|
||||||
|
httpRequest.getSession().setAttribute(HttpSessionIntegrationFilter.ACEGI_SECURITY_AUTHENTICATION_KEY,
|
||||||
|
null);
|
||||||
|
httpResponse.sendRedirect(httpRequest.getContextPath()
|
||||||
|
+ authenticationFailureUrl);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Authentication success
|
||||||
|
if (logger.isDebugEnabled()) {
|
||||||
|
logger.debug("Authentication success: " + authResult.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
httpRequest.getSession().setAttribute(HttpSessionIntegrationFilter.ACEGI_SECURITY_AUTHENTICATION_KEY,
|
||||||
|
authResult);
|
||||||
|
|
||||||
|
String targetUrl = (String) httpRequest.getSession().getAttribute(ACEGI_SECURITY_TARGET_URL_KEY);
|
||||||
|
httpRequest.getSession().setAttribute(ACEGI_SECURITY_TARGET_URL_KEY,
|
||||||
|
null);
|
||||||
|
|
||||||
|
if (targetUrl == null) {
|
||||||
|
targetUrl = defaultTargetUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (logger.isDebugEnabled()) {
|
||||||
|
logger.debug(
|
||||||
|
"Redirecting to target URL from HTTP Session (or default): "
|
||||||
|
+ targetUrl);
|
||||||
|
}
|
||||||
|
|
||||||
|
httpResponse.sendRedirect(httpRequest.getContextPath() + targetUrl);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
chain.doFilter(request, response);
|
||||||
|
}
|
||||||
|
}
|
|
@ -17,75 +17,24 @@ package net.sf.acegisecurity.ui.webapp;
|
||||||
|
|
||||||
import net.sf.acegisecurity.Authentication;
|
import net.sf.acegisecurity.Authentication;
|
||||||
import net.sf.acegisecurity.AuthenticationException;
|
import net.sf.acegisecurity.AuthenticationException;
|
||||||
import net.sf.acegisecurity.AuthenticationManager;
|
|
||||||
import net.sf.acegisecurity.providers.UsernamePasswordAuthenticationToken;
|
import net.sf.acegisecurity.providers.UsernamePasswordAuthenticationToken;
|
||||||
|
import net.sf.acegisecurity.ui.AbstractProcessingFilter;
|
||||||
|
|
||||||
import org.apache.commons.logging.Log;
|
|
||||||
import org.apache.commons.logging.LogFactory;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.InitializingBean;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import javax.servlet.Filter;
|
|
||||||
import javax.servlet.FilterChain;
|
|
||||||
import javax.servlet.FilterConfig;
|
import javax.servlet.FilterConfig;
|
||||||
import javax.servlet.ServletException;
|
import javax.servlet.ServletException;
|
||||||
import javax.servlet.ServletRequest;
|
|
||||||
import javax.servlet.ServletResponse;
|
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Processes an authentication form, putting the result into the
|
* Processes an authentication form.
|
||||||
* <code>HttpSession</code>.
|
|
||||||
*
|
|
||||||
* <p>
|
|
||||||
* This filter is responsible for processing authentication requests. A user
|
|
||||||
* will typically authenticate once using a login form, and this filter
|
|
||||||
* processes that form. If authentication is successful, the resulting {@link
|
|
||||||
* Authentication} object will be placed into the <code>HttpSession</code>
|
|
||||||
* with the attribute defined by {@link
|
|
||||||
* HttpSessionIntegrationFilter#ACEGI_SECURITY_AUTHENTICATION_KEY}.
|
|
||||||
* </p>
|
|
||||||
*
|
*
|
||||||
* <p>
|
* <p>
|
||||||
* Login forms must present two parameters to this filter: a username and
|
* Login forms must present two parameters to this filter: a username and
|
||||||
* password. The filter will process the login against the authentication
|
* password. The parameter names to use are contained in the static fields
|
||||||
* environment that was configured from a Spring application context defined
|
* {@link #ACEGI_SECURITY_FORM_USERNAME_KEY} and {@link
|
||||||
* in the filter initialization.
|
* #ACEGI_SECURITY_FORM_PASSWORD_KEY}.
|
||||||
* </p>
|
* </p>
|
||||||
*
|
*
|
||||||
* <p>
|
|
||||||
* If authentication fails, the <code>AuthenticationException</code> will be
|
|
||||||
* placed into the <code>HttpSession</code> with the attribute defined by
|
|
||||||
* {@link #ACEGI_SECURITY_LAST_EXCEPTION_KEY}.
|
|
||||||
* </p>
|
|
||||||
*
|
|
||||||
* <p>
|
|
||||||
* To use this filter, it is necessary to specify the following properties:
|
|
||||||
* </p>
|
|
||||||
*
|
|
||||||
* <ul>
|
|
||||||
* <li>
|
|
||||||
* <code>defaultTargetUrl</code> indicates the URL that should be used for
|
|
||||||
* redirection if the <code>HttpSession</code> attribute named {@link
|
|
||||||
* #ACEGI_SECURITY_TARGET_URL_KEY} does not indicate the target URL once
|
|
||||||
* authentication is completed successfully. eg: <code>/</code>.
|
|
||||||
* </li>
|
|
||||||
* <li>
|
|
||||||
* <code>authenticationFailureUrl</code> indicates the URL that should be used
|
|
||||||
* for redirection if the authentication request fails. eg:
|
|
||||||
* <code>/login.jsp?login_error=1</code>.
|
|
||||||
* </li>
|
|
||||||
* <li>
|
|
||||||
* <code>filterProcessesUrl</code> indicates the URL that this filter will
|
|
||||||
* respond to. This parameter is optional, and defaults to
|
|
||||||
* <code>/j_acegi_security_check</code>.
|
|
||||||
* </li>
|
|
||||||
* </ul>
|
|
||||||
*
|
|
||||||
* <P>
|
* <P>
|
||||||
* <B>Do not use this class directly.</B> Instead configure
|
* <B>Do not use this class directly.</B> Instead configure
|
||||||
* <code>web.xml</code> to use the {@link
|
* <code>web.xml</code> to use the {@link
|
||||||
|
@ -96,175 +45,40 @@ import javax.servlet.http.HttpServletResponse;
|
||||||
* @author Colin Sampaleanu
|
* @author Colin Sampaleanu
|
||||||
* @version $Id$
|
* @version $Id$
|
||||||
*/
|
*/
|
||||||
public class AuthenticationProcessingFilter implements Filter, InitializingBean {
|
public class AuthenticationProcessingFilter extends AbstractProcessingFilter {
|
||||||
//~ Static fields/initializers =============================================
|
//~ Static fields/initializers =============================================
|
||||||
|
|
||||||
public static final String ACEGI_SECURITY_TARGET_URL_KEY = "ACEGI_SECURITY_TARGET_URL";
|
|
||||||
public static final String ACEGI_SECURITY_FORM_USERNAME_KEY = "j_username";
|
public static final String ACEGI_SECURITY_FORM_USERNAME_KEY = "j_username";
|
||||||
public static final String ACEGI_SECURITY_FORM_PASSWORD_KEY = "j_password";
|
public static final String ACEGI_SECURITY_FORM_PASSWORD_KEY = "j_password";
|
||||||
public static final String ACEGI_SECURITY_LAST_EXCEPTION_KEY = "ACEGI_SECURITY_LAST_EXCEPTION";
|
|
||||||
private static final Log logger = LogFactory.getLog(AuthenticationProcessingFilter.class);
|
|
||||||
|
|
||||||
//~ Instance fields ========================================================
|
|
||||||
|
|
||||||
private AuthenticationManager authenticationManager;
|
|
||||||
|
|
||||||
/** Where to redirect the browser to if authentication fails */
|
|
||||||
private String authenticationFailureUrl;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Where to redirect the browser to if authentication is successful but
|
|
||||||
* ACEGI_SECURITY_TARGET_URL_KEY is <code>null</code>
|
|
||||||
*/
|
|
||||||
private String defaultTargetUrl;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The URL destination that this filter intercepts and processes (usually
|
|
||||||
* <code>/j_acegi_security_check</code>)
|
|
||||||
*/
|
|
||||||
private String filterProcessesUrl = "/j_acegi_security_check";
|
|
||||||
|
|
||||||
//~ Methods ================================================================
|
//~ Methods ================================================================
|
||||||
|
|
||||||
public void setAuthenticationFailureUrl(String authenticationFailureUrl) {
|
/**
|
||||||
this.authenticationFailureUrl = authenticationFailureUrl;
|
* This filter by default responds to <code>/j_acegi_security_check</code>.
|
||||||
|
*
|
||||||
|
* @return the default
|
||||||
|
*/
|
||||||
|
public String getDefaultFilterProcessesUrl() {
|
||||||
|
return "/j_acegi_security_check";
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getAuthenticationFailureUrl() {
|
public Authentication attemptAuthentication(HttpServletRequest request)
|
||||||
return authenticationFailureUrl;
|
throws AuthenticationException {
|
||||||
}
|
String username = request.getParameter(ACEGI_SECURITY_FORM_USERNAME_KEY);
|
||||||
|
String password = request.getParameter(ACEGI_SECURITY_FORM_PASSWORD_KEY);
|
||||||
|
|
||||||
public void setAuthenticationManager(
|
if (username == null) {
|
||||||
AuthenticationManager authenticationManager) {
|
username = "";
|
||||||
this.authenticationManager = authenticationManager;
|
|
||||||
}
|
|
||||||
|
|
||||||
public AuthenticationManager getAuthenticationManager() {
|
|
||||||
return authenticationManager;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setDefaultTargetUrl(String defaultTargetUrl) {
|
|
||||||
this.defaultTargetUrl = defaultTargetUrl;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getDefaultTargetUrl() {
|
|
||||||
return defaultTargetUrl;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setFilterProcessesUrl(String filterProcessesUrl) {
|
|
||||||
this.filterProcessesUrl = filterProcessesUrl;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getFilterProcessesUrl() {
|
|
||||||
return filterProcessesUrl;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void afterPropertiesSet() throws Exception {
|
|
||||||
if ((filterProcessesUrl == null) || "".equals(filterProcessesUrl)) {
|
|
||||||
throw new IllegalArgumentException(
|
|
||||||
"filterProcessesUrl must be specified");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((defaultTargetUrl == null) || "".equals(defaultTargetUrl)) {
|
if (password == null) {
|
||||||
throw new IllegalArgumentException(
|
password = "";
|
||||||
"defaultTargetUrl must be specified");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((authenticationFailureUrl == null)
|
UsernamePasswordAuthenticationToken authRequest = new UsernamePasswordAuthenticationToken(username,
|
||||||
|| "".equals(authenticationFailureUrl)) {
|
password);
|
||||||
throw new IllegalArgumentException(
|
|
||||||
"authenticationFailureUrl must be specified");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (authenticationManager == null) {
|
return this.getAuthenticationManager().authenticate(authRequest);
|
||||||
throw new IllegalArgumentException(
|
|
||||||
"authenticationManager must be specified");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void destroy() {}
|
|
||||||
|
|
||||||
public void doFilter(ServletRequest request, ServletResponse response,
|
|
||||||
FilterChain chain) throws IOException, ServletException {
|
|
||||||
if (!(request instanceof HttpServletRequest)) {
|
|
||||||
throw new ServletException("Can only process HttpServletRequest");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!(response instanceof HttpServletResponse)) {
|
|
||||||
throw new ServletException("Can only process HttpServletResponse");
|
|
||||||
}
|
|
||||||
|
|
||||||
HttpServletRequest httpRequest = (HttpServletRequest) request;
|
|
||||||
HttpServletResponse httpResponse = (HttpServletResponse) response;
|
|
||||||
|
|
||||||
if (filterProcessesUrl.equals(httpRequest.getServletPath())) {
|
|
||||||
if (logger.isDebugEnabled()) {
|
|
||||||
logger.debug("Request is to process Acegi login form");
|
|
||||||
}
|
|
||||||
|
|
||||||
String username = httpRequest.getParameter(ACEGI_SECURITY_FORM_USERNAME_KEY);
|
|
||||||
String password = httpRequest.getParameter(ACEGI_SECURITY_FORM_PASSWORD_KEY);
|
|
||||||
|
|
||||||
if (username == null) {
|
|
||||||
username = "";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (password == null) {
|
|
||||||
password = "";
|
|
||||||
}
|
|
||||||
|
|
||||||
UsernamePasswordAuthenticationToken authRequest = new UsernamePasswordAuthenticationToken(username,
|
|
||||||
password);
|
|
||||||
|
|
||||||
Authentication authResult;
|
|
||||||
|
|
||||||
try {
|
|
||||||
authResult = authenticationManager.authenticate(authRequest);
|
|
||||||
} catch (AuthenticationException failed) {
|
|
||||||
// Authentication failed
|
|
||||||
if (logger.isDebugEnabled()) {
|
|
||||||
logger.debug("Authentication request for user: " + username
|
|
||||||
+ " failed: " + failed.toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
httpRequest.getSession().setAttribute(ACEGI_SECURITY_LAST_EXCEPTION_KEY,
|
|
||||||
failed);
|
|
||||||
httpRequest.getSession().setAttribute(HttpSessionIntegrationFilter.ACEGI_SECURITY_AUTHENTICATION_KEY,
|
|
||||||
null);
|
|
||||||
httpResponse.sendRedirect(httpRequest.getContextPath()
|
|
||||||
+ authenticationFailureUrl);
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Authentication success
|
|
||||||
if (logger.isDebugEnabled()) {
|
|
||||||
logger.debug("Authentication success: " + authResult.toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
httpRequest.getSession().setAttribute(HttpSessionIntegrationFilter.ACEGI_SECURITY_AUTHENTICATION_KEY,
|
|
||||||
authResult);
|
|
||||||
|
|
||||||
String targetUrl = (String) httpRequest.getSession().getAttribute(AuthenticationProcessingFilter.ACEGI_SECURITY_TARGET_URL_KEY);
|
|
||||||
httpRequest.getSession().setAttribute(AuthenticationProcessingFilter.ACEGI_SECURITY_TARGET_URL_KEY,
|
|
||||||
null);
|
|
||||||
|
|
||||||
if (targetUrl == null) {
|
|
||||||
targetUrl = defaultTargetUrl;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (logger.isDebugEnabled()) {
|
|
||||||
logger.debug(
|
|
||||||
"Redirecting to target URL from HTTP Session (or default): "
|
|
||||||
+ targetUrl);
|
|
||||||
}
|
|
||||||
|
|
||||||
httpResponse.sendRedirect(httpRequest.getContextPath() + targetUrl);
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
chain.doFilter(request, response);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void init(FilterConfig filterConfig) throws ServletException {}
|
public void init(FilterConfig filterConfig) throws ServletException {}
|
||||||
|
|
Loading…
Reference in New Issue