Views: 144
In the previous tutorial, I introduced you how to work with .properties files using the Properties class. There are other needs related to configuration information of applications that this Properties class does not support, for example:
Reusing properties that have been declared in other properties is not supported.
Suppose I have the following properties:
|
huongdanjava.base.url=https://huongdanjava.com huongdanjava.contact.url=https://huongdanjava.com/vi/lien-he huongdanjava.introduction.url=https://huongdanjava.com/vi/gioi-thieu |
Because these properties have the same value at the beginning, I will need to reuse the property “huongdanjava.base.url” in other properties using variable interpolation with the syntax “${<property_name>}” as follows :
|
huongdanjava.base.url=https://huongdanjava.com huongdanjava.contact.url=${huongdanjava.base.url}/vi/lien-he huongdanjava.introduction.url=${huongdanjava.base.url}/vi/gioi-thieu |
So when I change the base url information, I just need to change the property “huongdanjava.base.url”.
Get configuration information from environment variables
When running an application, sometimes we will need to get the value of an environment variable to inject into the application’s configuration information. As in the example above, if the value of the property “huongdanjava.base.url” is not configured directly in the .properties file but will be taken from the environment variable “HUONGDANJAVA_BASE_URL”, what will I do? By default, the Properties class is not supported.
All of the above problems can be easily solved if you use the Apache Common Configuration.
How is it in detail? We will find out together in this tutorial!
I will create a Maven project as an example:
with Apache Common Configuration dependency is declared as follows:
|
<dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-configuration2</artifactId> <version>2.9.0</version> </dependency> <dependency> <groupId>commons-beanutils</groupId> <artifactId>commons-beanutils</artifactId> <version>1.9.4</version> </dependency> |
I will read the config.properties file located in the src/main/resources folder with the following content:
|
huongdanjava.base.url=https://huongdanjava.com huongdanjava.contact.url=${huongdanjava.base.url}/vi/lien-he huongdanjava.introduction.url=${huongdanjava.base.url}/vi/gioi-thieu |
If you use the Properties class, you will see the following results when reading the property “huongdanjava.contact.url”:
The value of the “huongdanjava.base.url” property has not been replaced in the value string of the “huongdanjava.contact.url” property as you can see!
Now, we will use Apache Common Configuration to solve this problem!
In Apache Common Configuration, the Configuration interface helps us work with all types of configurations that our application needs. For the .properties file, we will use the implementation of this Configuration interface, the PropertiesConfiguration class.
To read the contents of the .properties file with Apache Common Configuration, we will use the FileBasedConfigurationBuilder class with the PropertiesConfiguration class as the parameter as follows:
|
FileBasedConfigurationBuilder<FileBasedConfiguration> builder = new FileBasedConfigurationBuilder<>(PropertiesConfiguration.class); |
You need to specify the .properties file to read using the configure() method as follows:
|
Parameters parameters = new Parameters(); builder.configure(parameters.properties().setFile(path.toFile())); |
Now we can get the object of the Configuration class from the above class builder:
|
Configuration configuration = builder.getConfiguration(); |
Các bạn có thể lấy đối tượng của class Properties từ đối tượng Configuration này như sau:
|
Properties properties = ConfigurationConverter.getProperties(configuration); |
Now we can get the information in the .properties file using this Properties object.
You will see the following results:
when retrieving the value of property “huongdanjava.contact.url”:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
|
package com.huongdanjava.commonconfiguration; import java.nio.file.Path; import java.nio.file.Paths; import java.util.Properties; import org.apache.commons.configuration2.Configuration; import org.apache.commons.configuration2.ConfigurationConverter; import org.apache.commons.configuration2.FileBasedConfiguration; import org.apache.commons.configuration2.PropertiesConfiguration; import org.apache.commons.configuration2.builder.FileBasedConfigurationBuilder; import org.apache.commons.configuration2.builder.fluent.Parameters; import org.apache.commons.configuration2.ex.ConfigurationException; public class Application { public static void main(String[] args) throws ConfigurationException { Path path = Paths.get("src", "main", "resources", "config.properties"); FileBasedConfigurationBuilder<FileBasedConfiguration> builder = new FileBasedConfigurationBuilder<>( PropertiesConfiguration.class); Parameters parameters = new Parameters(); builder.configure(parameters.properties().setFile(path.toFile())); Configuration configuration = builder.getConfiguration(); Properties properties = ConfigurationConverter.getProperties(configuration); System.out.println(properties.getProperty("huongdanjava.contact.url")); } } |
So the value of the “huongdanjava.base.url” property has been replaced in the value of the “huongdanjava.contact.url” property!
To get the configuration information configured in the environment variable, you can declare the environment variable using variable interpolation starting with the keyword “env:” as follows:
|
huongdanjava.base.url=${env:HUONGDANJAVA_BASE_URL} huongdanjava.contact.url=${huongdanjava.base.url}/vi/lien-he huongdanjava.introduction.url=${huongdanjava.base.url}/vi/gioi-thieu |
At this point, if we get the value of the property “huongdanjava.introduction.url”:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
|
package com.huongdanjava.commonconfiguration; import java.nio.file.Path; import java.nio.file.Paths; import java.util.Properties; import org.apache.commons.configuration2.Configuration; import org.apache.commons.configuration2.ConfigurationConverter; import org.apache.commons.configuration2.FileBasedConfiguration; import org.apache.commons.configuration2.PropertiesConfiguration; import org.apache.commons.configuration2.builder.FileBasedConfigurationBuilder; import org.apache.commons.configuration2.builder.fluent.Parameters; import org.apache.commons.configuration2.ex.ConfigurationException; public class Application { public static void main(String[] args) throws ConfigurationException { Path path = Paths.get("src", "main", "resources", "config.properties"); FileBasedConfigurationBuilder<FileBasedConfiguration> builder = new FileBasedConfigurationBuilder<>( PropertiesConfiguration.class); Parameters parameters = new Parameters(); builder.configure(parameters.properties().setFile(path.toFile())); Configuration configuration = builder.getConfiguration(); Properties properties = ConfigurationConverter.getProperties(configuration); System.out.println(properties.getProperty("huongdanjava..url")); } } |
You will see the results we want as follows:
with the HUONGDANJAVA BASE_URL environment variable configured when running the example application as follows:
So, with Apache Common Configuration, we have solved the limitations of Java’s Properties class!