All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.springframework.context.annotation.PropertySource Maven / Gradle / Ivy

There is a newer version: 6.2.0
Show newest version
/*
 * Copyright 2002-2023 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
 *
 *      https://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.context.annotation;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Repeatable;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

import org.springframework.core.io.support.PropertySourceFactory;

/**
 * Annotation providing a convenient and declarative mechanism for adding a
 * {@link org.springframework.core.env.PropertySource PropertySource} to Spring's
 * {@link org.springframework.core.env.Environment Environment}. To be used in
 * conjunction with @{@link Configuration} classes.
 *
 * 

Example usage

* *

Given a file {@code app.properties} containing the key/value pair * {@code testbean.name=myTestBean}, the following {@code @Configuration} class * uses {@code @PropertySource} to contribute {@code app.properties} to the * {@code Environment}'s set of {@code PropertySources}. * *

 * @Configuration
 * @PropertySource("classpath:/com/myco/app.properties")
 * public class AppConfig {
 *
 *     @Autowired
 *     Environment env;
 *
 *     @Bean
 *     public TestBean testBean() {
 *         TestBean testBean = new TestBean();
 *         testBean.setName(env.getProperty("testbean.name"));
 *         return testBean;
 *     }
 * }
* *

Notice that the {@code Environment} object is * {@link org.springframework.beans.factory.annotation.Autowired @Autowired} into the * configuration class and then used when populating the {@code TestBean} object. Given * the configuration above, a call to {@code testBean.getName()} will return "myTestBean". * *

Resolving ${...} placeholders in {@code } and {@code @Value} annotations

* *

In order to resolve ${...} placeholders in {@code } definitions or {@code @Value} * annotations using properties from a {@code PropertySource}, you must ensure that an * appropriate embedded value resolver is registered in the {@code BeanFactory} * used by the {@code ApplicationContext}. This happens automatically when using * {@code } in XML. When using {@code @Configuration} classes * this can be achieved by explicitly registering a {@code PropertySourcesPlaceholderConfigurer} * via a {@code static} {@code @Bean} method. Note, however, that explicit registration * of a {@code PropertySourcesPlaceholderConfigurer} via a {@code static} {@code @Bean} * method is typically only required if you need to customize configuration such as the * placeholder syntax, etc. See the "Working with externalized values" section of * {@link Configuration @Configuration}'s javadocs and "a note on * BeanFactoryPostProcessor-returning {@code @Bean} methods" of {@link Bean @Bean}'s * javadocs for details and examples. * *

Resolving ${...} placeholders within {@code @PropertySource} resource locations

* *

Any ${...} placeholders present in a {@code @PropertySource} {@linkplain #value() * resource location} will be resolved against the set of property sources already * registered against the environment. For example: * *

 * @Configuration
 * @PropertySource("classpath:/com/${my.placeholder:default/path}/app.properties")
 * public class AppConfig {
 *
 *     @Autowired
 *     Environment env;
 *
 *     @Bean
 *     public TestBean testBean() {
 *         TestBean testBean = new TestBean();
 *         testBean.setName(env.getProperty("testbean.name"));
 *         return testBean;
 *     }
 * }
* *

Assuming that "my.placeholder" is present in one of the property sources already * registered — for example, system properties or environment variables — * the placeholder will be resolved to the corresponding value. If not, then "default/path" * will be used as a default. Expressing a default value (delimited by colon ":") is * optional. If no default is specified and a property cannot be resolved, an {@code * IllegalArgumentException} will be thrown. * *

A note on property overriding with {@code @PropertySource}

* *

In cases where a given property key exists in more than one property resource * file, the last {@code @PropertySource} annotation processed will 'win' and override * any previous key with the same name. * *

For example, given two properties files {@code a.properties} and * {@code b.properties}, consider the following two configuration classes * that reference them with {@code @PropertySource} annotations: * *

 * @Configuration
 * @PropertySource("classpath:/com/myco/a.properties")
 * public class ConfigA { }
 *
 * @Configuration
 * @PropertySource("classpath:/com/myco/b.properties")
 * public class ConfigB { }
 * 
* *

The override ordering depends on the order in which these classes are registered * with the application context. * *

 * AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext();
 * ctx.register(ConfigA.class);
 * ctx.register(ConfigB.class);
 * ctx.refresh();
 * 
* *

In the scenario above, the properties in {@code b.properties} will override any * duplicates that exist in {@code a.properties}, because {@code ConfigB} was registered * last. * *

In certain situations, it may not be possible or practical to tightly control * property source ordering when using {@code @PropertySource} annotations. For example, * if the {@code @Configuration} classes above were registered via component-scanning, * the ordering is difficult to predict. In such cases — and if overriding is important * — it is recommended that the user fall back to using the programmatic * {@code PropertySource} API. See {@link org.springframework.core.env.ConfigurableEnvironment * ConfigurableEnvironment} and {@link org.springframework.core.env.MutablePropertySources * MutablePropertySources} javadocs for details. * *

{@code @PropertySource} can be used as a {@linkplain Repeatable repeatable} * annotation. {@code @PropertySource} may also be used as a meta-annotation * to create custom composed annotations with attribute overrides. * * @author Chris Beams * @author Juergen Hoeller * @author Phillip Webb * @author Sam Brannen * @since 3.1 * @see PropertySources * @see Configuration * @see org.springframework.core.env.PropertySource * @see org.springframework.core.env.ConfigurableEnvironment#getPropertySources() * @see org.springframework.core.env.MutablePropertySources */ @Target(ElementType.TYPE) @Retention(RetentionPolicy.RUNTIME) @Documented @Repeatable(PropertySources.class) public @interface PropertySource { /** * Indicate the unique name of this property source. *

If omitted, the {@link #factory} will generate a name based on the * underlying resource (in the case of * {@link org.springframework.core.io.support.DefaultPropertySourceFactory * DefaultPropertySourceFactory}: derived from the resource description through * a corresponding name-less * {@link org.springframework.core.io.support.ResourcePropertySource * ResourcePropertySource} constructor). *

The name of a {@code PropertySource} serves two general purposes. *

    *
  • Diagnostics: to determine the source of the properties in logging and * debugging — for example, in a Spring Boot application via Spring * Boot's {@code PropertySourceOrigin}.
  • *
  • Programmatic interaction with * {@link org.springframework.core.env.MutablePropertySources MutablePropertySources}: * the name can be used to retrieve properties from a particular property * source (or to determine if a particular named property source already exists). * The name can also be used to add a new property source relative to an existing * property source (see * {@link org.springframework.core.env.MutablePropertySources#addBefore addBefore()} and * {@link org.springframework.core.env.MutablePropertySources#addAfter addAfter()}).
  • *
* @see org.springframework.core.env.PropertySource#getName() * @see org.springframework.core.io.Resource#getDescription() */ String name() default ""; /** * Indicate the resource locations of the properties files to be loaded. *

The default {@link #factory() factory} supports both traditional and * XML-based properties file formats — for example, * {@code "classpath:/com/myco/app.properties"} or {@code "file:/path/to/file.xml"}. *

As of Spring Framework 6.1, resource location wildcards are also * supported — for example, {@code "classpath*:/config/*.properties"}. *

{@code ${...}} placeholders will be resolved against property sources already * registered with the {@code Environment}. See {@linkplain PropertySource above} * for examples. *

Each location will be added to the enclosing {@code Environment} as its own * property source, and in the order declared (or in the order in which resource * locations are resolved when location wildcards are used). */ String[] value(); /** * Indicate if a failure to find a {@link #value property resource} should be * ignored. *

{@code true} is appropriate if the properties file is completely optional. *

Default is {@code false}. * @since 4.0 */ boolean ignoreResourceNotFound() default false; /** * A specific character encoding for the given resources, e.g. "UTF-8". * @since 4.3 */ String encoding() default ""; /** * Specify a custom {@link PropertySourceFactory}, if any. *

By default, a default factory for standard resource files will be used * which supports {@code *.properties} and {@code *.xml} file formats for * {@link java.util.Properties}. * @since 4.3 * @see org.springframework.core.io.support.DefaultPropertySourceFactory * @see org.springframework.core.io.support.ResourcePropertySource */ Class factory() default PropertySourceFactory.class; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy