url 中的参数出现 400 错误请求错误
Getting 400 bad request error for params in url
我正在尝试从数据库中获取数据它在邮递员中工作正常但是当我在本地主机上 运行 时抛出错误
获取所有学生的后端路线
用户需要登录、认证和管理员
// listng route
router.get(
"/students/:userId",
isSignedIn,
isAuthenticated,
isAdmin,
getAllStudents
);
后端处理请求的控制器
exports.getAllStudents = (req, res) => {
let sortBy = req.query.sortBy ? req.query.sortBy : "_id";
let limit = req.query.limit ? parseInt(req.query.limit) : 8;
Student.find()
.select("-address")
.populate("faculty")
.sort([[sortBy, "asc"]])
.limit(limit)
.exec((err, students) => {
if (err) {
return res.status(400)({
error: "No students found",
});
}
res.json(students);
});
};
以上代码适用于邮递员,但当我将其与前端连接时,出现以下错误
**Fetching API calls atb frontend**
export const getAllStudents = (userId, token) => {
return fetch(`${API}/students/${userId}`, {
method: "GET",
headers: {
Accept: "application/json",
Authorization: `Bearer ${token}`,
},
})
.then((response) => {
console.log("res :", response);
return response.json();
})
.catch((err) => console.log(err));
};
前端路由
<AdminRoutes path="/admin/students" exact component={ManageStudents} />
错误 - 它说 ${userId} id 未定义
我认为您的问题出在前端。您确定要将 userId
传递给 getAllStudents
函数吗?因为从您的网络结果来看,您似乎忘记了将任何参数传递给该函数。如果您在开始调用该函数的地方共享代码,那么回答起来会更容易。
我正在尝试从数据库中获取数据它在邮递员中工作正常但是当我在本地主机上 运行 时抛出错误 获取所有学生的后端路线 用户需要登录、认证和管理员
// listng route
router.get(
"/students/:userId",
isSignedIn,
isAuthenticated,
isAdmin,
getAllStudents
);
后端处理请求的控制器
exports.getAllStudents = (req, res) => {
let sortBy = req.query.sortBy ? req.query.sortBy : "_id";
let limit = req.query.limit ? parseInt(req.query.limit) : 8;
Student.find()
.select("-address")
.populate("faculty")
.sort([[sortBy, "asc"]])
.limit(limit)
.exec((err, students) => {
if (err) {
return res.status(400)({
error: "No students found",
});
}
res.json(students);
});
};
以上代码适用于邮递员,但当我将其与前端连接时,出现以下错误
**Fetching API calls atb frontend**
export const getAllStudents = (userId, token) => {
return fetch(`${API}/students/${userId}`, {
method: "GET",
headers: {
Accept: "application/json",
Authorization: `Bearer ${token}`,
},
})
.then((response) => {
console.log("res :", response);
return response.json();
})
.catch((err) => console.log(err));
};
前端路由
<AdminRoutes path="/admin/students" exact component={ManageStudents} />
错误 - 它说 ${userId} id 未定义
我认为您的问题出在前端。您确定要将 userId
传递给 getAllStudents
函数吗?因为从您的网络结果来看,您似乎忘记了将任何参数传递给该函数。如果您在开始调用该函数的地方共享代码,那么回答起来会更容易。