How To Use Environment Variables In Create React App And Netlify?
a beginner's guide
Environment Variables are essential for the security of your web application. There is a good chance that you are using GitHub to host your project publically. Within that project, if you are using an external API - you are probably using an API key. Now, if you are directly writing that API key in your code - you are sharing it on GitHub. Everyone can use it. They can access your sensitive information. They can exhaust your API Key's rate limit which can even cost you money. Environment Variables (env var) help prevent that.
So what exactly is an env var? To put it simply, it's a variable whose value is set outside the program. And it can be used inside a program through reference.
There are many ways to create an env var. In this article, we will focus on using it in Create React App and Netlify.
Using Create React App
In create-react-app, we first need to create a
.env file in the root folder (not src!) with the variable name starting with
It will look something like this:
Note: There are no spaces between the variable, equality sign and the value.
Now, you can directly access the env var in your app using
Here's a demo: codesandbox.io/s/env-var-6ytmj
.env to your
And we are done (at least the first part). You can push your code to GitHub and your API key will not be exposed.
Now, if you are using Netlify to deploy your app - the API key is not available. Your app will not work as you expect. We need to set the same env var in Netlify as well.
When you deploy your website to Netlify, click on
Show Advanced and add a new variable.
If you have already deployed your website, go to
Site settings > Build & deploy > Environment > Environment variables and click on
Edit Variables and add your env var.
And we are finally done. Now, our API key is secure. This is the basic setup, for more use-cases, please refer to:
Interested in reading more such articles from Rajat Gupta?
Support the author by donating an amount of your choice.