Class DelegatingFilterProxy
- All Implemented Interfaces:
jakarta.servlet.Filter, Aware, BeanNameAware, DisposableBean, InitializingBean, EnvironmentAware, EnvironmentCapable, ServletContextAware
web.xml, specifying the name of the target bean in the Spring
application context.
web.xml will usually contain a DelegatingFilterProxy definition,
with the specified filter-name corresponding to a bean name in
Spring's root application context. All calls to the filter proxy will then
be delegated to that bean in the Spring context, which is required to implement
the standard Servlet Filter interface.
This approach is particularly useful for Filter implementations with complex setup needs, allowing to apply the full Spring bean definition machinery to Filter instances. Alternatively, consider standard Filter setup in combination with looking up service beans from the Spring root application context.
NOTE: The lifecycle methods defined by the Servlet Filter interface
will by default not be delegated to the target bean, relying on the
Spring application context to manage the lifecycle of that bean. Specifying
the "targetFilterLifecycle" filter init-param as "true" will enforce invocation
of the Filter.init(jakarta.servlet.FilterConfig) and
Filter.destroy() lifecycle methods on the target bean, letting the
Servlet container manage the filter lifecycle.
DelegatingFilterProxy can optionally accept constructor parameters
when using a Servlet container's instance-based filter registration methods,
usually in conjunction with Spring's
WebApplicationInitializer SPI. These constructors allow
for providing the delegate Filter bean directly, or providing the application context
and bean name to fetch, avoiding the need to look up the application context from the
ServletContext.
This class was originally inspired by Spring Security's FilterToBeanProxy
class, written by Ben Alex.
- Since:
- 1.2
- Author:
- Juergen Hoeller, Sam Brannen, Chris Beams
- See Also:
-
Field Summary
Fields inherited from class GenericFilterBean
logger -
Constructor Summary
ConstructorsConstructorDescriptionCreate a newDelegatingFilterProxy.DelegatingFilterProxy(jakarta.servlet.Filter delegate) Create a newDelegatingFilterProxywith the givenFilterdelegate.DelegatingFilterProxy(String targetBeanName) Create a newDelegatingFilterProxythat will retrieve the named target bean from the SpringWebApplicationContextfound in theServletContext(either the 'root' application context or the context named bysetContextAttribute(String)).DelegatingFilterProxy(String targetBeanName, @nullable WebApplicationContext wac) Create a newDelegatingFilterProxythat will retrieve the named target bean from the given SpringWebApplicationContext. -
Method Summary
Modifier and TypeMethodDescriptionvoiddestroy()Subclasses may override this to perform custom filter shutdown.protected voiddestroyDelegate(jakarta.servlet.Filter delegate) Destroy the Filter delegate.voiddoFilter(jakarta.servlet.ServletRequest request, jakarta.servlet.ServletResponse response, jakarta.servlet.FilterChain filterChain) protected @nullable WebApplicationContextReturn theWebApplicationContextpassed in at construction time, if available.Return the name of the ServletContext attribute which should be used to retrieve theWebApplicationContextfrom which to load the delegateFilterbean.Return the name of the target bean in the Spring application context.protected jakarta.servlet.FilterInitialize the Filter delegate, defined as bean the given Spring application context.protected voidSubclasses may override this to perform custom initialization.protected voidinvokeDelegate(jakarta.servlet.Filter delegate, jakarta.servlet.ServletRequest request, jakarta.servlet.ServletResponse response, jakarta.servlet.FilterChain filterChain) Actually invoke the delegate Filter with the given request and response.protected booleanReturn whether to invoke theFilter.initandFilter.destroylifecycle methods on the target bean.voidsetContextAttribute(@nullable String contextAttribute) Set the name of the ServletContext attribute which should be used to retrieve theWebApplicationContextfrom which to load the delegateFilterbean.voidsetTargetBeanName(@nullable String targetBeanName) Set the name of the target bean in the Spring application context.voidsetTargetFilterLifecycle(boolean targetFilterLifecycle) Set whether to invoke theFilter.initandFilter.destroylifecycle methods on the target bean.Methods inherited from class GenericFilterBean
addRequiredProperty, afterPropertiesSet, createEnvironment, getEnvironment, getFilterConfig, getFilterName, getServletContext, init, initBeanWrapper, setBeanName, setEnvironment, setServletContext
-
Constructor Details
-
DelegatingFilterProxy
public DelegatingFilterProxy()Create a newDelegatingFilterProxy. For traditional use inweb.xml.- See Also:
-
DelegatingFilterProxy
public DelegatingFilterProxy(jakarta.servlet.Filter delegate) Create a newDelegatingFilterProxywith the givenFilterdelegate. Bypasses entirely the need for interacting with a Spring application context, specifying the target bean name, etc.For use with instance-based registration of filters.
- Parameters:
delegate- theFilterinstance that this proxy will delegate to and manage the lifecycle for (must not benull).- See Also:
-
DelegatingFilterProxy
Create a newDelegatingFilterProxythat will retrieve the named target bean from the SpringWebApplicationContextfound in theServletContext(either the 'root' application context or the context named bysetContextAttribute(String)).For use with instance-based registration of filters.
The target bean must implement the standard Servlet Filter interface.
- Parameters:
targetBeanName- name of the target filter bean to look up in the Spring application context (must not benull).- See Also:
-
DelegatingFilterProxy
Create a newDelegatingFilterProxythat will retrieve the named target bean from the given SpringWebApplicationContext.For use with instance-based registration of filters.
The target bean must implement the standard Servlet Filter interface.
The given
WebApplicationContextmay or may not be refreshed when passed in. If it has not, and if the context implementsConfigurableApplicationContext, arefresh()will be attempted before retrieving the named target bean.This proxy's
Environmentwill be inherited from the givenWebApplicationContext.- Parameters:
targetBeanName- name of the target filter bean in the Spring application context (must not benull).wac- the application context from which the target filter will be retrieved; ifnull, an application context will be looked up fromServletContextas a fallback.- See Also:
-
-
Method Details
-
setContextAttribute
Set the name of the ServletContext attribute which should be used to retrieve theWebApplicationContextfrom which to load the delegateFilterbean. -
getContextAttribute
Return the name of the ServletContext attribute which should be used to retrieve theWebApplicationContextfrom which to load the delegateFilterbean. -
setTargetBeanName
-
getTargetBeanName
-
setTargetFilterLifecycle
public void setTargetFilterLifecycle(boolean targetFilterLifecycle) Set whether to invoke theFilter.initandFilter.destroylifecycle methods on the target bean.Default is "false"; target beans usually rely on the Spring application context for managing their lifecycle. Setting this flag to "true" means that the servlet container will control the lifecycle of the target Filter, with this proxy delegating the corresponding calls.
-
isTargetFilterLifecycle
protected boolean isTargetFilterLifecycle()Return whether to invoke theFilter.initandFilter.destroylifecycle methods on the target bean. -
initFilterBean
protected void initFilterBean() throws jakarta.servlet.ServletExceptionDescription copied from class:GenericFilterBeanSubclasses may override this to perform custom initialization. All bean properties of this filter will have been set before this method is invoked.Note: This method will be called from standard filter initialization as well as filter bean initialization in a Spring application context. Filter name and ServletContext will be available in both cases.
This default implementation is empty.
- Overrides:
initFilterBeanin classGenericFilterBean- Throws:
jakarta.servlet.ServletException- if subclass initialization fails- See Also:
-
doFilter
public void doFilter(jakarta.servlet.ServletRequest request, jakarta.servlet.ServletResponse response, jakarta.servlet.FilterChain filterChain) throws jakarta.servlet.ServletException, IOException - Throws:
jakarta.servlet.ServletExceptionIOException
-
destroy
public void destroy()Description copied from class:GenericFilterBeanSubclasses may override this to perform custom filter shutdown.Note: This method will be called from standard filter destruction as well as filter bean destruction in a Spring application context.
This default implementation is empty.
- Specified by:
destroyin interfaceDisposableBean- Specified by:
destroyin interfacejakarta.servlet.Filter- Overrides:
destroyin classGenericFilterBean
-
findWebApplicationContext
Return theWebApplicationContextpassed in at construction time, if available. Otherwise, attempt to retrieve aWebApplicationContextfrom theServletContextattribute with the configured name if set. Otherwise look up aWebApplicationContextunder the well-known "root" application context attribute. TheWebApplicationContextmust have already been loaded and stored in theServletContextbefore this filter gets initialized (or invoked).Subclasses may override this method to provide a different
WebApplicationContextretrieval strategy.- Returns:
- the
WebApplicationContextfor this proxy, ornullif not found - See Also:
-
initDelegate
protected jakarta.servlet.Filter initDelegate(WebApplicationContext wac) throws jakarta.servlet.ServletException Initialize the Filter delegate, defined as bean the given Spring application context.The default implementation fetches the bean from the application context and calls the standard
Filter.initmethod on it, passing in the FilterConfig of this Filter proxy.- Parameters:
wac- the root application context- Returns:
- the initialized delegate Filter
- Throws:
jakarta.servlet.ServletException- if thrown by the Filter- See Also:
-
invokeDelegate
protected void invokeDelegate(jakarta.servlet.Filter delegate, jakarta.servlet.ServletRequest request, jakarta.servlet.ServletResponse response, jakarta.servlet.FilterChain filterChain) throws jakarta.servlet.ServletException, IOException Actually invoke the delegate Filter with the given request and response.- Parameters:
delegate- the delegate Filterrequest- the current HTTP requestresponse- the current HTTP responsefilterChain- the current FilterChain- Throws:
jakarta.servlet.ServletException- if thrown by the FilterIOException- if thrown by the Filter
-
destroyDelegate
protected void destroyDelegate(jakarta.servlet.Filter delegate) Destroy the Filter delegate. Default implementation simply callsFilter.destroyon it.- Parameters:
delegate- the Filter delegate (nevernull)- See Also:
-