在使用 Express 和 next() 函数的中间件之后无法获取
Cannot GET after middleware using Express and next() function
我正在尝试应用一个修改“req”参数的中间件,在我最终使用 next() 函数之前它工作得很好。这是来自中间件的代码:
auth.js
import jwt from "jsonwebtoken";
export const auth = (req, res, next) => {
try{
const token = req.header("x-auth-token");
if(!token) return res.status(401).json({msg: "No authentication token, access denied"});
const verified = jwt.verify(token, process.env.JWT_SIGNIN_KEY);
if(!verified) return res.status(401).json({msg: "Token verification failed, authorization denied"});
req.user = verified._id;
next();
} catch (err) {
res.status(500).json({ error: err.message });
}
}
这个中间件在users控制器中执行,如下:
userController.js
export const userIndex = asyncHandler(auth, async (req, res) => {
const user = await User.findById(req.user);
res.json({
displayName: user.displayName,
id: user._id,
});
})
然后我将这个函数关联到用户路由:
userRoutes.js
import { googleLogin, tokenIsValid, userIndex } from "../controllers/userController.js";
import express from 'express'
const router = express.Router()
router.route('/getUser').get(userIndex)
router.route('/googlelogin').post(googleLogin)
router.route('/tokenIsValid').post(tokenIsValid)
export default router
import connectDB from './backend/config/db.js'
import userRoutes from './backend/routes/userRoutes.js'
import dotenv from 'dotenv'
import express from 'express'
connectDB() // Ejecuto la conexión a la base de datos
dotenv.config() // Llamo a las variables de .env
const app = express() // Defino el servidor
app.use(express.json()); // Permite que el servidor entienda los datos enviados en formato JSON
app.use('/api/users', userRoutes) // Creo las rutas para el usuario
const PORT = process.env.PORT || 5000 // Defino un puerto para el servidor
// Ejecuto el servidor
app.listen(PORT, console.log(`La aplicación está corriendo en entorno de ${process.env.NODE_ENV} sobre el puerto ${PORT}`))
我调用这条路由时出现问题,总是return 404错误:
我认为这个错误发生在 next() 函数之前。
有线索吗?
谢谢大家!!
检查你使用的包后,它只需要一个函数作为参数,但你传递了多个,这会导致错误。我将按以下方式更改您的代码:
userController.js
export const userIndex = asyncHandler(async (req, res) => {
const user = await User.findById(req.user);
res.json({
displayName: user.displayName,
id: user._id,
});
})
userRoutes.js
import { googleLogin, tokenIsValid, userIndex } from "../controllers/userController.js";
import express from 'express'
const router = express.Router()
router.get('/getUser', auth, userIndex)
router.post('/googlelogin', googleLogin)
router.post('/tokenIsValid', tokenIsValid)
export default router
我正在尝试应用一个修改“req”参数的中间件,在我最终使用 next() 函数之前它工作得很好。这是来自中间件的代码:
auth.js
import jwt from "jsonwebtoken";
export const auth = (req, res, next) => {
try{
const token = req.header("x-auth-token");
if(!token) return res.status(401).json({msg: "No authentication token, access denied"});
const verified = jwt.verify(token, process.env.JWT_SIGNIN_KEY);
if(!verified) return res.status(401).json({msg: "Token verification failed, authorization denied"});
req.user = verified._id;
next();
} catch (err) {
res.status(500).json({ error: err.message });
}
}
这个中间件在users控制器中执行,如下:
userController.js
export const userIndex = asyncHandler(auth, async (req, res) => {
const user = await User.findById(req.user);
res.json({
displayName: user.displayName,
id: user._id,
});
})
然后我将这个函数关联到用户路由:
userRoutes.js
import { googleLogin, tokenIsValid, userIndex } from "../controllers/userController.js";
import express from 'express'
const router = express.Router()
router.route('/getUser').get(userIndex)
router.route('/googlelogin').post(googleLogin)
router.route('/tokenIsValid').post(tokenIsValid)
export default router
import connectDB from './backend/config/db.js'
import userRoutes from './backend/routes/userRoutes.js'
import dotenv from 'dotenv'
import express from 'express'
connectDB() // Ejecuto la conexión a la base de datos
dotenv.config() // Llamo a las variables de .env
const app = express() // Defino el servidor
app.use(express.json()); // Permite que el servidor entienda los datos enviados en formato JSON
app.use('/api/users', userRoutes) // Creo las rutas para el usuario
const PORT = process.env.PORT || 5000 // Defino un puerto para el servidor
// Ejecuto el servidor
app.listen(PORT, console.log(`La aplicación está corriendo en entorno de ${process.env.NODE_ENV} sobre el puerto ${PORT}`))
我调用这条路由时出现问题,总是return 404错误:
我认为这个错误发生在 next() 函数之前。
有线索吗?
谢谢大家!!
检查你使用的包后,它只需要一个函数作为参数,但你传递了多个,这会导致错误。我将按以下方式更改您的代码:
userController.js
export const userIndex = asyncHandler(async (req, res) => {
const user = await User.findById(req.user);
res.json({
displayName: user.displayName,
id: user._id,
});
})
userRoutes.js
import { googleLogin, tokenIsValid, userIndex } from "../controllers/userController.js";
import express from 'express'
const router = express.Router()
router.get('/getUser', auth, userIndex)
router.post('/googlelogin', googleLogin)
router.post('/tokenIsValid', tokenIsValid)
export default router