Top 10 Solutions for Building a Powerful CRUD API

Jennie Lee
7 min readApr 10, 2024

--

Looking for a Postman alternative?

Try APIDog, the Most Customizable Postman Alternative, where you can connect to thousands of APIs right now!

Introduction

The concept of a CRUD API is of paramount importance in database operations. CRUD stands for Create, Read, Update, and Delete, which are the fundamental operations performed on a database. A CRUD API allows developers to interact with a database by providing endpoints for these operations.

In this tutorial, we will explore how to build a powerful CRUD API using Node.js. Node.js is a popular runtime environment for building server-side applications because of its efficient event-driven architecture and non-blocking I/O model.

The objective of this tutorial is to provide a step-by-step guide on building a RESTful CRUD API using Node.js. We will cover the installation process, setting up the project, and implementing the necessary API endpoints for each CRUD operation.

Let’s dive into the first step of setting up the project.

Setting up the Project

To get started with building a CRUD API using Node.js, we need to set up the project and install the necessary dependencies. Here are the steps to follow:

  1. Installation of Node.js and npm: Node.js comes with npm (Node Package Manager) out of the box. Visit the official Node.js website (https://nodejs.org) to download and install the latest LTS version of Node.js.
  2. Initializing the project directory: After installing Node.js, open your terminal or command prompt and create a new directory for your project. Navigate into the project directory and run the following command to initialize a new Node.js project:
  • npm init
  1. This command will prompt you to enter some information about your project, such as the package name, version, description, entry point, etc. You can press Enter to accept the default values or provide your own.
  2. Installing required dependencies: We need to install several dependencies to build our CRUD API. These dependencies include Express, Helmet, Morgan, Body-parser, Monk, Joi, and dotenv. Let’s install them one by one using the following command:
  • npm install express helmet morgan body-parser monk joi dotenv
  • Express: Express is a fast and minimalist web application framework for Node.js. It provides a robust set of features for web and mobile applications.
  • Helmet: Helmet is a security middleware for Express that helps in securing your web applications by setting various HTTP headers.
  • Morgan: Morgan is a logging middleware for Express that provides detailed request logging.
  • Body-parser: Body-parser is a middleware for Express that parses the request body and makes it accessible in the req.body property.
  • Monk: Monk is a lightweight MongoDB driver for Node.js that simplifies database operations.
  • Joi: Joi is a validation library for JavaScript that helps in validating request data.
  • Dotenv: Dotenv is a zero-dependency module that loads environment variables from a .env file into process.env.
  1. Once the dependencies are installed, we’re ready to start building our API.

Building the RESTful CRUD API

Now that we have set up the project and installed the required dependencies, it’s time to build the RESTful CRUD API. We will implement each API endpoint step by step using Express.js. Let’s get started.

A. Retrieving all Employees

The first API endpoint we’ll implement is for retrieving all employees from the database. Let’s name the endpoint GET /api/employees. Here’s how we can implement it:

  1. Create a new file named index.js in the project directory.
  2. Import the required dependencies at the top of the file:
  • const express = require('express'); const helmet = require('helmet'); const morgan = require('morgan'); const bodyParser = require('body-parser'); const monk = require('monk'); const Joi = require('joi'); require('dotenv').config();
  1. Create an instance of Express and configure the middleware:
  • const app = express(); app.use(helmet()); app.use(morgan('dev')); app.use(bodyParser.json()); app.use(bodyParser.urlencoded({ extended: true }));
  1. Set up the database connection using Monk:
  • const db = monk(process.env.MONGO_URI);
  1. Make sure to set the MONGO_URI environment variable in the .env file.
  2. Define the GET /api/employees endpoint and retrieve all employees from the database:
  • app.get('/api/employees', async (req, res) => { const employees = await db.get('employees').find({}); res.json(employees); });
  1. This code retrieves all the documents from the “employees” collection in the database and sends the response as JSON.
  2. Start the server by listening on a port:
  • app.listen(3000, () => { console.log('Server listening on port 3000'); });
  1. Replace 3000 with your desired port number.

Congratulations! You have successfully implemented the GET /api/employees endpoint to retrieve all employees from the database. You can test the API using tools like cURL or Postman.

B. Retrieving a Specific Employee

Next, let’s implement the API endpoint for retrieving a specific employee based on their ID. The endpoint will be GET /api/employees/:id. Here’s how to implement it:

  1. Add the following code below the GET /api/employees endpoint:
  • app.get('/api/employees/:id', async (req, res) => { const { id } = req.params; const employee = await db.get('employees').findOne({ _id: id }); if (!employee) { return res.status(404).json({ message: 'Employee not found' }); } res.json(employee); });
  1. This code retrieves the employee with the specified ID from the “employees” collection. If the employee is not found, it sends a 404 status code with an error message.
  2. Test the API by making a GET request to /api/employees/:id, where :id is the ID of an existing employee.

Great job! You now have an API endpoint that retrieves a specific employee from the database based on their ID.

C. Creating a New Employee

Let’s move on to implementing the API endpoint for creating a new employee. The endpoint will be POST /api/employees. Here’s how to implement it:

  1. Add the following code below the GET /api/employees/:id endpoint:
  • const employeeSchema = Joi.object({ name: Joi.string().required(), age: Joi.number().integer().min(18).max(65).required(), position: Joi.string().required(), }); app.post('/api/employees', async (req, res) => { const { error } = employeeSchema.validate(req.body); if (error) { return res.status(400).json({ message: error.details[0].message }); } const employee = { name: req.body.name, age: req.body.age, position: req.body.position, }; const insertedEmployee = await db.get('employees').insert(employee); res.status(201).json(insertedEmployee); });
  1. This code validates the request body against the defined employee schema using Joi. If the request body is invalid, it sends a 400 status code with an error message. Otherwise, it inserts the new employee into the database and sends the inserted document as the response with a 201 status code.
  2. Test the API by making a POST request to /api/employees with a JSON payload containing the required fields (name, age, position) for creating a new employee.

Fantastic! You have successfully implemented the POST /api/employees endpoint to create a new employee in the database.

D. Updating an Existing Employee

Let’s proceed to implement the API endpoint for updating an existing employee based on their ID. The endpoint will be PUT /api/employees/:id. Here’s how to implement it:

  1. Add the following code below the POST /api/employees endpoint:
  • const updateEmployeeSchema = Joi.object({ name: Joi.string(), age: Joi.number().integer().min(18).max(65), position: Joi.string(), }).min(1); app.put('/api/employees/:id', async (req, res) => { const { id } = req.params; const { error } = updateEmployeeSchema.validate(req.body); if (error) { return res.status(400).json({ message: error.details[0].message }); } const employee = await db.get('employees').findOne({ _id: id }); if (!employee) { return res.status(404).json({ message: 'Employee not found' }); } const updatedEmployee = { name: req.body.name || employee.name, age: req.body.age || employee.age, position: req.body.position || employee.position, }; await db.get('employees').update({ _id: id }, updatedEmployee); res.json(updatedEmployee); });
  1. This code validates the request body against the defined update employee schema using Joi. If the request body is invalid, it sends a 400 status code with an error message. Otherwise, it retrieves the employee with the specified ID from the database, updates the relevant fields with the request body or keeps the existing values if not provided, and updates the employee in the database. Finally, it sends the updated employee as the response.
  2. Test the API by making a PUT request to /api/employees/:id with a JSON payload containing the fields (name, age, position) that you want to update for an existing employee.

Wonderful! You have now implemented the PUT /api/employees/:id endpoint to update an existing employee in the database.

E. Deleting an Existing Employee

Lastly, let’s implement the API endpoint for deleting an existing employee based on their ID. The endpoint will be DELETE /api/employees/:id. Here’s how to implement it:

  1. Add the following code below the PUT /api/employees/:id endpoint:
  • app.delete('/api/employees/:id', async (req, res) => { const { id } = req.params; const employee = await db.get('employees').findOne({ _id: id }); if (!employee) { return res.status(404).json({ message: 'Employee not found' }); } await db.get('employees').remove({ _id: id }); res.json({ message: 'Employee deleted successfully' }); });
  1. This code retrieves the employee with the specified ID from the database. If the employee is not found, it sends a 404 status code with an error message. Otherwise, it removes the employee from the database and sends a success message as the response.
  2. Test the API by making a DELETE request to /api/employees/:id, where :id is the ID of an existing employee.

Congratulations! You have successfully implemented the DELETE /api/employees/:id endpoint to delete an existing employee from the database.

Conclusion

In this tutorial, we have explored how to build a powerful CRUD API using Node.js. We started by setting up the project and installing the necessary dependencies. Then, we implemented the API endpoints for each CRUD operation step-by-step using Express.js.

We covered functionalities such as retrieving all employees, retrieving a specific employee, creating a new employee, updating an existing employee, and deleting an employee. We also included error handling middleware and database connection configuration.

By following this tutorial, you now have the knowledge and sample codes to build a robust CRUD API using Node.js. Feel free to customize and extend the API to suit your specific needs. Happy coding!

Looking for a Postman alternative?

Try APIDog, the Most Customizable Postman Alternative, where you can connect to thousands of APIs right now!

--

--

Jennie Lee
Jennie Lee

Written by Jennie Lee

Software Testing Blogger, #API Testing

No responses yet