首页 > 解决方案 > 在 next.js 编译时,中间件被命中太多次

问题描述

我正在使用 next.js 和 express.js 。如果我使用中间件 (server.use(req, res, next)),它会在页面编译时被命中几十次,这会使我的应用程序完全崩溃......

const express = require('express')
const next = require('next')

const port = parseInt(process.env.PORT, 10) || 3000
const dev = process.env.NODE_ENV !== 'production'
const app = next({ dev })
const handle = app.getRequestHandler()

console.log('page loaded')

app.prepare().then(() => {
const server = express()

server.use((req, res, next) => {
  console.log('ping')
  next();
})

server.get('/', (req, res) => {
  return app.render(req, res, '/index', req.query)
})

server.get('*', (req, res) => {
  return handle(req, res)
})

server.listen(port, err => {
  if (err) throw err
  console.log(`> Ready on http://localhost:${port}`)
})
})

如果我尝试加载页面,它会打印

ping
ping
ping
ping
ping
ping
ping
ping
ping
ping
ping
ping
ping
ping
ping

当然,如果我在这里放置一个真正的中间件,它会使一切崩溃......

我希望中间件只有在页面实际请求某些东西时才运行......所以每个“真实用户”请求只有一次

标签: expressmiddlewarenext.js

解决方案


推荐阅读