Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Вивчайте Створення Кінцевої Точки DELETE Для Видалення Поста За Ідентифікатором | Створення REST API з Використанням Node.js та Express.js
Розробка бекенду з Node.js та Express.js

bookСтворення Кінцевої Точки DELETE Для Видалення Поста За Ідентифікатором

Ми розглянемо реалізацію маршруту "DELETE POST BY ID" у файлі postsRoutes.js. Цей маршрут дозволяє клієнтам видаляти конкретний пост, вказавши його унікальний ідентифікатор.

Визначення маршруту

Наведений нижче код визначає маршрут "DELETE POST BY ID" за допомогою router.delete():

router.delete("/post/:id", async (req, res, next) => { ... }

Цей маршрут обробляє HTTP DELETE-запити з параметризованим :id у шляху маршруту. Параметр :id використовується для ідентифікації поста, який потрібно видалити. Додаткові проміжні обробники, такі як dataValidation, не потрібні, оскільки вся необхідна інформація отримується з параметра URL.

Витягування ідентифікатора поста

Ми отримуємо ідентифікатор поста з параметрів запиту за допомогою req.params.id:

const postId = req.params.id;

Цей рядок зчитує значення :id з URL, що дозволяє використовувати його в подальшому коді.

Видалення поста

Ось як відбувається видалення поста:

const data = await readData();

const postIndex = data.findIndex((post) => post.id === postId);

if (postIndex === -1) {
  return res.status(404).json({ error: "Post not found" });
}

data.splice(postIndex, 1);

await fs.writeFile("./database/posts.json", JSON.stringify(data));
  • Спочатку зчитуються наявні дані з JSON-файлу за допомогою асинхронної функції readData, як було описано раніше.
  • Визначається індекс поста для видалення у масиві data шляхом порівняння ідентифікаторів постів.
  • Якщо пост не знайдено (тобто postIndex === -1), повертається відповідь 404 (Not Found) з повідомленням про помилку.
  • За допомогою методу splice дані поста видаляються з масиву data. Змінна postIndex визначає позицію поста для видалення.
  • Оновлений масив data з видаленим постом записується назад у JSON-файл для збереження змін, внесених під час видалення.

Відправлення відповіді

Клієнту надсилається JSON-відповідь зі статус-кодом 200 (OK), що вказує на успішне видалення. У відповіді міститься повідомлення, яке підтверджує, що пост було успішно видалено:

res.status(200).json({ message: "Post deleted successfully" });

Обробка помилок

Код маршруту обгортається у блок try-catch для обробки можливих помилок під час отримання даних або обробки запиту. Усі помилки, що виникають, записуються у консоль для налагодження:

try {
  // ... (code for retrieving and processing data)
} catch (error) {
  console.error(error.message);
}

Повний код файлу postsRoutes.js на цьому етапі

const express = require("express");
const fs = require("fs/promises");
const validatePostData = require("../middlewares/validateData");

const router = express.Router();

// Function to read data from the JSON file
async function readData() {
  try {
    // Read the contents of the `posts.json` file
    const data = await fs.readFile("./database/posts.json");
    // Parse the JSON data into a JavaScript object
    return JSON.parse(data);
  } catch (error) {
    // If an error occurs during reading or parsing, throw the error
    throw error;
  }
}

// GET ALL POSTS
router.get("/", async (req, res, next) => {
  try {
    // Call the `readData` function to retrieve the list of posts
    const data = await readData();
    // Send the retrieved data as the response
    res.status(200).send(data);
  } catch (error) {
    // If an error occurs during data retrieval or sending the response
    console.error(error.message); // Log the error to the console for debugging
  }
});

// GET POST BY ID
router.get("/post/:id", async (req, res, next) => {
  try {
    // Extract the post ID from the request parameters
    const postId = req.params.id;
    // Read data from the JSON file
    const data = await readData();

    // Find the post with the matching ID
    const post = data.find((post) => post.id === postId);

    // If the post is not found, send a 404 response
    if (!post) {
      res.status(404).json({ error: "Post not found" });
    } else {
      // If the post is found, send it as the response
      res.status(200).send(post);
    }
  } catch (error) {
    // Handle errors by logging them and sending an error response
    console.error(error.message);
  }
});

// CREATE POST
router.post("/", validatePostData, async (req, res, next) => {
  try {
    const newPost = {
      id: Date.now().toString(), // Generate a unique ID for the new post
      username: req.body.username,
      postTitle: req.body.postTitle,
      postContent: req.body.postContent,
    };

    // Read the existing data
    const data = await readData();

    // Add the new post to the data
    data.push(newPost);

    // Write the updated data back to the JSON file
    await fs.writeFile("./database/posts.json", JSON.stringify(data));

    // Send a success response with the new post
    res.status(201).json(newPost);
  } catch (error) {
    // Handle errors by logging them to the console
    console.error(error.message);
  }
});

// UPDATE POST BY ID
router.put("/post/:id", validatePostData, async (req, res, next) => {
  try {
    // Extract the post ID from the request parameters
    const postId = req.params.id;
    // Extract the updated data from the request body
    const updatedData = {
      username: req.body.username,
      postTitle: req.body.postTitle,
      postContent: req.body.postContent,
    };

    // Read the existing data
    const data = await readData();

    // Find the index of the post with the specified ID in the data array
    const postIndex = data.findIndex((post) => post.id === postId);

    // If the post with the specified ID doesn't exist, return a 404 error
    if (postIndex === -1) {
      return res.status(404).json({ error: "Post not found" });
    }

    // Update the post data with the new data using spread syntax
    data[postIndex] = {
      ...data[postIndex], // Keep existing data
      ...updatedData, // Apply updated data
    };

    // Write the updated data back
    await fs.writeFile("./database/posts.json", JSON.stringify(data));

    // Send a success response with the updated post
    res.status(200).json(data[postIndex]);
  } catch (error) {
    console.error(error.message);
    next(error);
  }
});

// DELETE POST BY ID
router.delete("/post/:id", async (req, res, next) => {
  try {
    // Extract the post ID from the request parameters
    const postId = req.params.id;

    // Read the existing data
    const data = await readData();

    // Find the index of the post with the specified ID in the data array
    const postIndex = data.findIndex((post) => post.id === postId);

    // If the post with the specified ID doesn't exist, return a 404 error
    if (postIndex === -1) {
      return res.status(404).json({ error: "Post not found" });
    }

    // Remove the post from the data array using `splice`
    data.splice(postIndex, 1);

    // Write the updated data back to the data source (e.g., a JSON file)
    await fs.writeFile("./database/posts.json", JSON.stringify(data));

    // Send a success response with the JSON response indicating successful deletion
    res.status(200).json({ message: "Post deleted successfully" });
  } catch (error) {
    console.error(error.message);
    next(error);
  }
});

module.exports = router;

Все було зрозуміло?

Як ми можемо покращити це?

Дякуємо за ваш відгук!

Секція 4. Розділ 9

Запитати АІ

expand

Запитати АІ

ChatGPT

Запитайте про що завгодно або спробуйте одне із запропонованих запитань, щоб почати наш чат

Suggested prompts:

Can you explain how the error handling works in the DELETE route?

What would happen if the post ID provided does not exist?

Can you summarize the main steps involved in deleting a post?

Awesome!

Completion rate improved to 2.56

bookСтворення Кінцевої Точки DELETE Для Видалення Поста За Ідентифікатором

Свайпніть щоб показати меню

Ми розглянемо реалізацію маршруту "DELETE POST BY ID" у файлі postsRoutes.js. Цей маршрут дозволяє клієнтам видаляти конкретний пост, вказавши його унікальний ідентифікатор.

Визначення маршруту

Наведений нижче код визначає маршрут "DELETE POST BY ID" за допомогою router.delete():

router.delete("/post/:id", async (req, res, next) => { ... }

Цей маршрут обробляє HTTP DELETE-запити з параметризованим :id у шляху маршруту. Параметр :id використовується для ідентифікації поста, який потрібно видалити. Додаткові проміжні обробники, такі як dataValidation, не потрібні, оскільки вся необхідна інформація отримується з параметра URL.

Витягування ідентифікатора поста

Ми отримуємо ідентифікатор поста з параметрів запиту за допомогою req.params.id:

const postId = req.params.id;

Цей рядок зчитує значення :id з URL, що дозволяє використовувати його в подальшому коді.

Видалення поста

Ось як відбувається видалення поста:

const data = await readData();

const postIndex = data.findIndex((post) => post.id === postId);

if (postIndex === -1) {
  return res.status(404).json({ error: "Post not found" });
}

data.splice(postIndex, 1);

await fs.writeFile("./database/posts.json", JSON.stringify(data));
  • Спочатку зчитуються наявні дані з JSON-файлу за допомогою асинхронної функції readData, як було описано раніше.
  • Визначається індекс поста для видалення у масиві data шляхом порівняння ідентифікаторів постів.
  • Якщо пост не знайдено (тобто postIndex === -1), повертається відповідь 404 (Not Found) з повідомленням про помилку.
  • За допомогою методу splice дані поста видаляються з масиву data. Змінна postIndex визначає позицію поста для видалення.
  • Оновлений масив data з видаленим постом записується назад у JSON-файл для збереження змін, внесених під час видалення.

Відправлення відповіді

Клієнту надсилається JSON-відповідь зі статус-кодом 200 (OK), що вказує на успішне видалення. У відповіді міститься повідомлення, яке підтверджує, що пост було успішно видалено:

res.status(200).json({ message: "Post deleted successfully" });

Обробка помилок

Код маршруту обгортається у блок try-catch для обробки можливих помилок під час отримання даних або обробки запиту. Усі помилки, що виникають, записуються у консоль для налагодження:

try {
  // ... (code for retrieving and processing data)
} catch (error) {
  console.error(error.message);
}

Повний код файлу postsRoutes.js на цьому етапі

const express = require("express");
const fs = require("fs/promises");
const validatePostData = require("../middlewares/validateData");

const router = express.Router();

// Function to read data from the JSON file
async function readData() {
  try {
    // Read the contents of the `posts.json` file
    const data = await fs.readFile("./database/posts.json");
    // Parse the JSON data into a JavaScript object
    return JSON.parse(data);
  } catch (error) {
    // If an error occurs during reading or parsing, throw the error
    throw error;
  }
}

// GET ALL POSTS
router.get("/", async (req, res, next) => {
  try {
    // Call the `readData` function to retrieve the list of posts
    const data = await readData();
    // Send the retrieved data as the response
    res.status(200).send(data);
  } catch (error) {
    // If an error occurs during data retrieval or sending the response
    console.error(error.message); // Log the error to the console for debugging
  }
});

// GET POST BY ID
router.get("/post/:id", async (req, res, next) => {
  try {
    // Extract the post ID from the request parameters
    const postId = req.params.id;
    // Read data from the JSON file
    const data = await readData();

    // Find the post with the matching ID
    const post = data.find((post) => post.id === postId);

    // If the post is not found, send a 404 response
    if (!post) {
      res.status(404).json({ error: "Post not found" });
    } else {
      // If the post is found, send it as the response
      res.status(200).send(post);
    }
  } catch (error) {
    // Handle errors by logging them and sending an error response
    console.error(error.message);
  }
});

// CREATE POST
router.post("/", validatePostData, async (req, res, next) => {
  try {
    const newPost = {
      id: Date.now().toString(), // Generate a unique ID for the new post
      username: req.body.username,
      postTitle: req.body.postTitle,
      postContent: req.body.postContent,
    };

    // Read the existing data
    const data = await readData();

    // Add the new post to the data
    data.push(newPost);

    // Write the updated data back to the JSON file
    await fs.writeFile("./database/posts.json", JSON.stringify(data));

    // Send a success response with the new post
    res.status(201).json(newPost);
  } catch (error) {
    // Handle errors by logging them to the console
    console.error(error.message);
  }
});

// UPDATE POST BY ID
router.put("/post/:id", validatePostData, async (req, res, next) => {
  try {
    // Extract the post ID from the request parameters
    const postId = req.params.id;
    // Extract the updated data from the request body
    const updatedData = {
      username: req.body.username,
      postTitle: req.body.postTitle,
      postContent: req.body.postContent,
    };

    // Read the existing data
    const data = await readData();

    // Find the index of the post with the specified ID in the data array
    const postIndex = data.findIndex((post) => post.id === postId);

    // If the post with the specified ID doesn't exist, return a 404 error
    if (postIndex === -1) {
      return res.status(404).json({ error: "Post not found" });
    }

    // Update the post data with the new data using spread syntax
    data[postIndex] = {
      ...data[postIndex], // Keep existing data
      ...updatedData, // Apply updated data
    };

    // Write the updated data back
    await fs.writeFile("./database/posts.json", JSON.stringify(data));

    // Send a success response with the updated post
    res.status(200).json(data[postIndex]);
  } catch (error) {
    console.error(error.message);
    next(error);
  }
});

// DELETE POST BY ID
router.delete("/post/:id", async (req, res, next) => {
  try {
    // Extract the post ID from the request parameters
    const postId = req.params.id;

    // Read the existing data
    const data = await readData();

    // Find the index of the post with the specified ID in the data array
    const postIndex = data.findIndex((post) => post.id === postId);

    // If the post with the specified ID doesn't exist, return a 404 error
    if (postIndex === -1) {
      return res.status(404).json({ error: "Post not found" });
    }

    // Remove the post from the data array using `splice`
    data.splice(postIndex, 1);

    // Write the updated data back to the data source (e.g., a JSON file)
    await fs.writeFile("./database/posts.json", JSON.stringify(data));

    // Send a success response with the JSON response indicating successful deletion
    res.status(200).json({ message: "Post deleted successfully" });
  } catch (error) {
    console.error(error.message);
    next(error);
  }
});

module.exports = router;

Все було зрозуміло?

Як ми можемо покращити це?

Дякуємо за ваш відгук!

Секція 4. Розділ 9
some-alt