Get-pyynnön Rakentaminen Postaukselle Tunnisteen Perusteella
Tässä osiossa tarkastellaan "GET POST BY ID" -reitin toteutusta postsRoutes.js file-tiedostossa. Tämä reitti hakee ja palauttaa tietyn postauksen sen yksilöllisen tunnisteen (id) perusteella, joka annetaan osana URL-osoitetta.
Huomio
Termi 'tietokanta' viittaa nimenomaan
posts.json-tiedostoon, joka sijaitseedatabase-kansiossa.
Reitin määrittely
Alla oleva koodi määrittelee "GET POST BY ID" -reitin käyttäen router.get():
router.get("/post/:id", async (req, res, next) => { ... }
- Tämä reitti on määritelty käsittelemään HTTP GET -pyyntöjä;
- Reitin polku
/post/:idsisältää parametrin:id, joka tallentaa postauksen tunnisteen URL-osoitteesta.
Postauksen tunnisteen poimiminen
Postauksen tunniste poimitaan pyynnön parametreista käyttäen req.params.id:
const postId = req.params.id;
Tämä rivi tallentaa URL-osoitteesta saadun :id-arvon jatkokäsittelyä varten.
Postauksen etsiminen tietokannasta
Seuraavaksi etsitään tietokannasta postaus, jonka tunniste täsmää:
const data = await readData();
const post = data.find((post) => post.id === postId);
- Asynkronista
readData-funktiota käytetään tietojen hakemiseen JSON-tiedostosta; find()-metodia käytetään etsimään postaus, jonka tunniste täsmää haettuun arvoon;post-muuttujaan tallennetaan löytynyt postaus taiundefined, jos vastaavuutta ei löydy.
Vastauksen käsittely
Vastaus käsitellään sen perusteella, löytyikö julkaisua vai ei:
if (!post) {
res.status(404).json({ error: "Post not found" });
} else {
res.status(200).send(post);
}
- Jos julkaisua ei löytynyt (eli
postonundefined), lähetetään 404-vastaus ja virheilmoitus, joka osoittaa, että pyydettyä julkaisua ei löytynyt; - Jos julkaisu löytyi, lähetetään julkaisu vastauksena tilakoodilla 200 (OK).
Virheenkäsittely
Reittikoodi kääritään try-catch-lohkoon mahdollisten virheiden käsittelemiseksi tiedonhakuprosessin tai pyynnön käsittelyn aikana. Kaikki esiintyvät virheet kirjataan konsoliin vianmääritystä varten:
try {
// ... (code for retrieving and processing data)
} catch (error) {
console.error(error.message);
}
postsRoutes.js-tiedoston täydellinen koodi tässä vaiheessa
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);
}
});
Kiitos palautteestasi!
Kysy tekoälyä
Kysy tekoälyä
Kysy mitä tahansa tai kokeile jotakin ehdotetuista kysymyksistä aloittaaksesi keskustelumme
Awesome!
Completion rate improved to 2.56
Get-pyynnön Rakentaminen Postaukselle Tunnisteen Perusteella
Pyyhkäise näyttääksesi valikon
Tässä osiossa tarkastellaan "GET POST BY ID" -reitin toteutusta postsRoutes.js file-tiedostossa. Tämä reitti hakee ja palauttaa tietyn postauksen sen yksilöllisen tunnisteen (id) perusteella, joka annetaan osana URL-osoitetta.
Huomio
Termi 'tietokanta' viittaa nimenomaan
posts.json-tiedostoon, joka sijaitseedatabase-kansiossa.
Reitin määrittely
Alla oleva koodi määrittelee "GET POST BY ID" -reitin käyttäen router.get():
router.get("/post/:id", async (req, res, next) => { ... }
- Tämä reitti on määritelty käsittelemään HTTP GET -pyyntöjä;
- Reitin polku
/post/:idsisältää parametrin:id, joka tallentaa postauksen tunnisteen URL-osoitteesta.
Postauksen tunnisteen poimiminen
Postauksen tunniste poimitaan pyynnön parametreista käyttäen req.params.id:
const postId = req.params.id;
Tämä rivi tallentaa URL-osoitteesta saadun :id-arvon jatkokäsittelyä varten.
Postauksen etsiminen tietokannasta
Seuraavaksi etsitään tietokannasta postaus, jonka tunniste täsmää:
const data = await readData();
const post = data.find((post) => post.id === postId);
- Asynkronista
readData-funktiota käytetään tietojen hakemiseen JSON-tiedostosta; find()-metodia käytetään etsimään postaus, jonka tunniste täsmää haettuun arvoon;post-muuttujaan tallennetaan löytynyt postaus taiundefined, jos vastaavuutta ei löydy.
Vastauksen käsittely
Vastaus käsitellään sen perusteella, löytyikö julkaisua vai ei:
if (!post) {
res.status(404).json({ error: "Post not found" });
} else {
res.status(200).send(post);
}
- Jos julkaisua ei löytynyt (eli
postonundefined), lähetetään 404-vastaus ja virheilmoitus, joka osoittaa, että pyydettyä julkaisua ei löytynyt; - Jos julkaisu löytyi, lähetetään julkaisu vastauksena tilakoodilla 200 (OK).
Virheenkäsittely
Reittikoodi kääritään try-catch-lohkoon mahdollisten virheiden käsittelemiseksi tiedonhakuprosessin tai pyynnön käsittelyn aikana. Kaikki esiintyvät virheet kirjataan konsoliin vianmääritystä varten:
try {
// ... (code for retrieving and processing data)
} catch (error) {
console.error(error.message);
}
postsRoutes.js-tiedoston täydellinen koodi tässä vaiheessa
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);
}
});
Kiitos palautteestasi!