Reading from a file in Node.js

In this lightning tutorial, we'll walk through what it takes to read a file using Node.js, using a practical, real-world example where our basic app will read from a configuration file (a .env file in this case).

0. Install Node.js

There are many different ways to install Node.js on your machine. I personally use NVM to manage multiple node versions on my machine with ease, but it's really up to you. Some of your options include:

To ensure you have installed Node.js on your machine successfully, from your command line, run: node -v which will output the current verions of Node.js installed on your machine.

Checking the Node.js version installed on your machine

1. Setup the project structure

Once you have installed Node.js, let's configure the basic project structure for our tutorial. We'll use a more conventional project structure where the app code lives in a src/ directory, and other artifacts and config files such as the  .env file live outside of the src/ directory.

# create a directory
mkdir node-read-file

# change into the new directory
cd node-read-file

# create src dir
mkdir src

# create .env file
touch .env

# change into src dir
cd src

# create main app file
touch app.js

2. Add environment variables to .env file

In today's day and age, a lot of apps – either knowingly or unknowingly – adhere to the principles outlined in "The Twelve-Factor App".

The 3rd factor of a Twelve-Factor App is "Config", which is essentially anything that will vary between deploys. For example, the database your application connects to during local development would (and should!) likely be different than the database your app uses in production. Database credentials are almost always a good candidate to store in configuration, such a .env file.

Add these environment variables to your .env:

DATABASE_HOST=localhost
DATABASE_PORT=5432
DATABASE_NAME=codesnippet
DATABASE_USER=codesnippet_user
DATABASE_PASSWORD=passw0rd1234!

3. Read the .env file in src/app.js

Now that we have setup our .env file with some environment variables, we can now read the .env in our application, and use the environment variables as needed.

In the src/app.js file, let's add some code:

const fs = require('node:fs/promises');

async function main() {
    // get the current working directory
    const currentDir = process.cwd();

    // navigate up one level to where the .env file is located
    const envFile = await fs.readFile(`${currentDir}/../.env`, 'utf-8');

    // parse the .env file into a javascript object
    const env = convertEnvFileToObject(envFile);

    // connect to our dummy database
    // passing in the environment variables as parameters
    connectToDatabase({
        host: env.DB_HOST,
        port: env.DB_PORT,
        name: env.DB_NAME,
        user: env.DB_USER,
        password: env.DB_PASSWORD,
    });
}

function connectToDatabase({ host, port, name, user, password }) {
    // check that all the required parameters are present
    if (!host || !port || !name || !user || !password) {
        throw new Error('Invalid database configuration');
    }
    console.log(`Successfully connected to database: ${user}:${password}@${host}:${port}/${name}`);
}

function convertEnvFileToObject(file) {
    // split the file into lines
    const lines = file.split('\n');
    // create an empty object to store the parsed values
    const parsed = {};

    // iterate over each line of the file
    for (const line of lines) {
        // skip comments
        if (line.startsWith('#')) {
            continue;
        }

        // split the line into key and value
        const [key, value] = line.split('=');
        // store the key and value in the object
        parsed[key] = value;
    }
    // return the parsed object
    return parsed;
}

main().catch((err) => console.error(err));

It's worth noting that the reading of the file itself occurs in essentially one line of code, where we call fs.readFile() which is an asynchronous operation that returns the contents of the specified file.

👉
Refer to the Node.js docs here for a little more information on how to use the fs.readFile() API.

4. Running the app

The last thing left for us to do is to run our application, we can do this from the command line. Make sure you're in the root directory of you project, and the run node src/app.js. You should then see log output indicating that our application successfully read from the .env file using the fs.readFile() API, and connected to our dummy "database"!

👉
View the source code: https://github.com/CodeSnippetHQ/tutorial-node-read-file