What's the difference between exposing environment variables in nextjs through the next.config.js vs with the NEXT_PUBLIC prefix?
Solution 1:
NEXT_PUBLIC
is a new feature added. Before, in order to set up environment variables, we had to set up both for server and client.
environment variables that are placed in the .env file would be available only on the server-side, if you want to make your env variables available at client-side you had to use next.config.js
. We follow separation of concerns principle here.
With NEXT_PUBLIC
, env variables will be available both client-side and server-side. env variables that set with NEXT_PUBLIC
will be exposed to the browser.
So in summary, adding the prefix NEXT_PUBLIC
to your environment variables will have the same effect of exposing to the browser your environment variables as exposing them through next.config.js
.
Their isn't much of a difference.
try this:
place this to .env or env.development file. NOT to next.config.js
MY_VAR=10
then run this:
console.log("MY var",process.env.MY_VAR);
both inside client component and getServerSideProps
function.
if you check the browser console, you will get undefined
, but on terminal you will see
MY var 10
Solution 2:
The difference between to the two is the one of them uses a .env file whereas the other uses the next.config file. Since Next.js 9.4, loading environment variables with .env files are now supported.
However, to clarify one thing in your question, all environment variables within the .env file don't have to be prefixed with NEXT_PUBLIC
, only the ones you want exposed to the browser, any without that prefix will only be accessible on the server.