/*
 * Copyright 2002-2017 the original author or authors.
 *
 * 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 org.springframework.web.context.support;

import javax.servlet.ServletConfig;
import javax.servlet.ServletContext;

import org.springframework.beans.BeansException;
import org.springframework.beans.factory.config.BeanPostProcessor;
import org.springframework.lang.Nullable;
import org.springframework.web.context.ServletConfigAware;
import org.springframework.web.context.ServletContextAware;

BeanPostProcessor implementation that passes the ServletContext to beans that implement the ServletContextAware interface.

Web application contexts will automatically register this with their underlying bean factory. Applications do not use this directly.

Author:Juergen Hoeller, Phillip Webb
See Also:
Since:12.03.2004
/** * {@link org.springframework.beans.factory.config.BeanPostProcessor} * implementation that passes the ServletContext to beans that implement * the {@link ServletContextAware} interface. * * <p>Web application contexts will automatically register this with their * underlying bean factory. Applications do not use this directly. * * @author Juergen Hoeller * @author Phillip Webb * @since 12.03.2004 * @see org.springframework.web.context.ServletContextAware * @see org.springframework.web.context.support.XmlWebApplicationContext#postProcessBeanFactory */
public class ServletContextAwareProcessor implements BeanPostProcessor { @Nullable private ServletContext servletContext; @Nullable private ServletConfig servletConfig;
Create a new ServletContextAwareProcessor without an initial context or config. When this constructor is used the getServletContext() and/or getServletConfig() methods should be overridden.
/** * Create a new ServletContextAwareProcessor without an initial context or config. * When this constructor is used the {@link #getServletContext()} and/or * {@link #getServletConfig()} methods should be overridden. */
protected ServletContextAwareProcessor() { }
Create a new ServletContextAwareProcessor for the given context.
/** * Create a new ServletContextAwareProcessor for the given context. */
public ServletContextAwareProcessor(ServletContext servletContext) { this(servletContext, null); }
Create a new ServletContextAwareProcessor for the given config.
/** * Create a new ServletContextAwareProcessor for the given config. */
public ServletContextAwareProcessor(ServletConfig servletConfig) { this(null, servletConfig); }
Create a new ServletContextAwareProcessor for the given context and config.
/** * Create a new ServletContextAwareProcessor for the given context and config. */
public ServletContextAwareProcessor(@Nullable ServletContext servletContext, @Nullable ServletConfig servletConfig) { this.servletContext = servletContext; this.servletConfig = servletConfig; }
Returns the ServletContext to be injected or null. This method can be overridden by subclasses when a context is obtained after the post-processor has been registered.
/** * Returns the {@link ServletContext} to be injected or {@code null}. This method * can be overridden by subclasses when a context is obtained after the post-processor * has been registered. */
@Nullable protected ServletContext getServletContext() { if (this.servletContext == null && getServletConfig() != null) { return getServletConfig().getServletContext(); } return this.servletContext; }
Returns the ServletConfig to be injected or null. This method can be overridden by subclasses when a context is obtained after the post-processor has been registered.
/** * Returns the {@link ServletConfig} to be injected or {@code null}. This method * can be overridden by subclasses when a context is obtained after the post-processor * has been registered. */
@Nullable protected ServletConfig getServletConfig() { return this.servletConfig; } @Override public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException { if (getServletContext() != null && bean instanceof ServletContextAware) { ((ServletContextAware) bean).setServletContext(getServletContext()); } if (getServletConfig() != null && bean instanceof ServletConfigAware) { ((ServletConfigAware) bean).setServletConfig(getServletConfig()); } return bean; } @Override public Object postProcessAfterInitialization(Object bean, String beanName) { return bean; } }