繁体   English   中英

将自定义中间件放在自定义next.js服务器的链中?

[英]Put custom middleware last in the chain in a custom next.js server?

我正在尝试将自定义中间件添加到自定义next.js服务器 但是,没有可绑定中间件的特定路径模式,因为这些URL是由我们的CMS生成的,几乎可以是任何东西 因此,我想中间链中添加我的中间件。 作为最终的包罗万象。 但是我找不到有关如何实现此目标的任何文档。

我试图将中间件放到最后,但这导致它从未被调用。

工作,但丑陋,而不是未来的证明:

//Our custom middleware first
server.get('*', [customMiddleware, standardMiddleware])
...
const customMiddleware = async function (req, res, next) {
  const parsedUrl = parse(req.url, true)
  const { pathname, query } = parsedUrl
  console.log("Custom middleware. pathname: " + pathname)
  if (pathname.startsWith("/babel/") || pathname.startsWith("/_next/") || pathname.startsWith("/static/") ...etc) {
    return next()
  }
  ///Custom logic here...
}

const standardMiddleware = function (req, res, next) {
  const parsedUrl = parse(req.url, true)
  const { pathname, query } = parsedUrl
  console.log("Standard middleware. pathname: " + pathname)
  return handle(req, res)
}

无法运作:

//Our custom middleware last
server.get('*', [standardMiddleware, customMiddleware])
...
const standardMiddleware = function (req, res, next) {
  const parsedUrl = parse(req.url, true)
  const { pathname, query } = parsedUrl
  console.log("Standard middleware. pathname: " + pathname)
  return handle(req, res)
}

const customMiddleware = async function (req, res, next) {
  const parsedUrl = parse(req.url, true)
  const { pathname, query } = parsedUrl
  console.log("Custom middleware. pathname: " + pathname)
  ///Custom logic here...
}

当我在上面标记为“不工作”的代码上运行时,我希望next.js处理它可以处理的所有请求,然后回退到customMiddleware来处理所有其他请求。 实际发生的事情是它永远不会回退到customMiddleware ,它只会为未知路径返回404

更新2019-02-13

由于当前的NextJS代码似乎无法实现,因此我将其添加为功能请求

为了说明我上面的评论:

const standardMiddleware = function (req, res, next) { // next is a callback argument here
  const parsedUrl = parse(req.url, true)
  const { pathname, query } = parsedUrl
  console.log("Standard middleware. pathname: " + pathname)
  return handle(req, res, next); // pass it along
}
...
function handle(req, res, next) {
  ...
  if (noRouteEventuallyMatched) {
    // res.status(404).sendFile('/path/to/my404.html');
    next(); // instead of setting res, call next so that the next element in the chain is tried
  }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM