Setting Environment Variables in Java
Setting & Working with Environment Variables in Java
Environment variables are a great way to configure Java applications without having to explicitly store settings and secure credentials in code, such as for database and caching servers, or for third-party APIs.
Keeping such settings outside of the code has several distinct advantages:
- Avoids the need to update and recompile code when settings change
- Helps prevent exposing sensitive credentials, such as usernames and passwords, and deployment tokens
- You can deploy the same code in multiple environments
In this short article, I'm going to show you what environment variables are, along with several ways to get and set them when working with Java.
What is an environment variable?
Environment variables are key/value pairs available within the environment in which your code is operating. These are used for storing a range of different types of information which your code needs, such as API keys and email addresses.
A key benefit of using them is that you can avoid hardcoding them in your code. This has several knock-on benefits. For example, your code doesn't need to be updated as and when the variables change. Secondly, they won't accidentally be version controlled, nor able to be extracted from your code by a malicious actor.
You can see several examples below.
Is it necessary to set environment variables for Java?
If the environment variable that your code needs is one of the ones defined by your operating system, such as %COMPUTERNAME%
by Microsoft Windows or $HOME
on Linux, macOS, and FreeBSD, then no. Otherwise, yes, they need to be set either by your code, or by the process that launches your Java application.
How to get environment variables in Java
One of the most common ways is to use System.getenv(), which accepts an optional String argument. Based on whether a String argument is passed, a different value is returned from the method. Specifically:
If a String is passed and it matches a key in the internal environment Map, then its value is returned. If a matching key is not found, null is returned. If a String argument is not passed, a read-only java.util.Map containing all environment variables and their values is returned. The Map's keys are the environment variable names and its values are the values.
Below, you can see an example of how to use the method to retrieve the Linux SHELL
environment variable (which contains the user's shell).
How to set environment variables in Java
As well as reading environment variables, it's helpful to know how to set them. I won't go into too much detail, instead sticking to the essentials. However, if you'd like to learn about them in greater depth, Dominik Kundel has written a detailed blog post about them.
On UNIX, Linux, and macOS
You can set environment variables in three core ways, when developing on UNIX, Linux, and macOS.
1. Set them in the current session and all child processes
You can initialise environment variables so that they're available to the current session, both the current one and any started in the current session, as well as any processes started in the current session, by using the builtin export command, as in the example below.
2. Set them only in the current session
You can initialise an environment variable so that it's available to the current session but not any child processes, as in the example below, by not using the export
command.
3. Set them for a specific process
Finally, you can initialise an environment variable so that it's available only to a specific process. This is helpful when only that process needs the variable. You initialise it as in the example below, when starting the desired process.
On Microsoft Windows
Setting environment variables is a little different in Microsoft Windows. You can either set them via the Control Panel, or you can set them in the command prompt or PowerShell console. There are examples of the latter two below.
Use .env files
While setting environment variables this way can be very effective, it can also become cumbersome rather quickly. For example, by setting them in the operating system's shell, there is no concrete list of the variables which the application needs, nor is there information available about what a variable is for or what data type it must be.
Given that, among other reasons, The 12-Factor App recommended a strict separation of config from code. This practice quickly took hold throughout the developer community commonly through the use of .env (dotenv) files. These are plain text files that store a list of key/value pairs, defining the environment variables required for an application to work, as in the example below.
To simplify getting started on a project, a further common practice emerged, that of including a .env.example file in a project which contains all of the keys—but without their values. When a new developer started working on the application, they would copy the file, naming it .env and set values for each key applicable to their local development environment.
Assuming that the example above was the .env file for our project, we could use a package such as dotenv-java to make the variables available to our application.
You can see an example of using the package in the code example below.
The code initialises a new Dotenv
object, dotenv, and calls Dotenv.configure().load()
to read in the environment variables in .env, located in the project's root directory. Following that, dotenv.get()
is used to retrieve the value of the String
object passed to it. If a matching key is not found, the method returns null
.
A note about .env file security
It's important to bear in mind that if sensitive data is stored in .env, that it must not be stored under version control. If that happens, then all of the security benefits of using dotenv files is lost. That's why it's common to exclude them from version control, such as by adding .env (and variations of the filename) to a project's .gitignore file when using Git.
That's how to work with environment variables in Java
I hope this article helped you understand how to use environment variables in your Java projects.
Do you have any other ways to work with environment variables? I’d love to know!
Matthew Setter is a PHP Editor in the Twilio Voices team and a polyglot developer. He’s also the author of Mezzio Essentials and Docker Essentials. When he’s not writing PHP code, he’s editing great PHP articles here at Twilio. You can find him at msetter@twilio.com; he's also settermjd on Twitter and GitHub.
Related Posts
Related Resources
Twilio Docs
From APIs to SDKs to sample apps
API reference documentation, SDKs, helper libraries, quickstarts, and tutorials for your language and platform.
Resource Center
The latest ebooks, industry reports, and webinars
Learn from customer engagement experts to improve your own communication.
Ahoy
Twilio's developer community hub
Best practices, code samples, and inspiration to build communications and digital engagement experiences.