• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

177
Views
Reacciona, ¿cómo puedes pasar una variable a una solicitud de obtención?

Estoy tratando de consultar desde una tabla donde el teacherId del maestro es igual al ID del teacherId de la persona que inicia sesión, pero no puedo pasar ese teacherId del maestro del front-end al back-end.

Esta es la parte de atrás

 app.get("/api/get", async(req,res) => { const teacherId = req.body.teacherId connection.query( "SELECT class FROM homework WHERE teacherID = ?", [teacherId], (err, result) => { if (result){ res.send({ message: result }) } else{ console.log(err) } } ) })

Este es el frente

 useEffect(() => { Axios.get("http://localhost:1337/api/get", { teacherId: teacherId }).then((response) => { if(response){ setDisplayHomework(response.data.message) } else{ console.log("error") } }) })
 const teacherId = localStorage.getItem("teacherId")

Creo que el problema radica donde dice teacherId: teacherId pero no sé por qué.

almost 3 years ago · Juan Pablo Isaza
3 answers
Answer question

0

necesitas usar

 Axios.get("http://localhost:1337/api/get", { params: { teacherId } });

y use req.query.teacherId para leerlo


Si ve la firma Axios.get , es

axios.get(url[, configuración])

en contraste con

axios.post(url[, datos[, configuración]])

que pasa los datos como el segundo argumento.

Esto se debe a que los servidores no utilizan el cuerpo de las solicitudes GET . Lea HTTP GET con el cuerpo de la solicitud para obtener más información al respecto.

almost 3 years ago · Juan Pablo Isaza Report

0

Por lo general, no envía un cuerpo con una solicitud de obtención. Ponga la identificación del maestro en la url. Entonces esto se llama variable de ruta.

 app.use('/teacher/:teacherId', function(req, res, next) { console.log(req.params.teacherId); next(); })
almost 3 years ago · Juan Pablo Isaza Report

0

Las solicitudes de obtención no tienen cuerpos de solicitud a diferencia de las solicitudes de publicación, por lo que la función Axios.get no debería tener un segundo parámetro para el cuerpo. En su lugar, pase sus parámetros como una URL, así:

 useEffect(() => { Axios.get("http://localhost:1337/api/get?teacherId="+teacherId).then((response) => { if(response){ setDisplayHomework(response.data.message) } else{ console.log("error") } }) })

Luego, en su código de back-end, use req.params para acceder a los parámetros de URL de solicitud de obtención:

 app.get("/api/get", async(req,res) => { const teacherId = req.params.teacherId connection.query( "SELECT class FROM homework WHERE teacherID = ?", [teacherId], (err, result) => { if (result){ res.send({ message: result }) } else{ console.log(err) } } ) })
almost 3 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error