在CMS Update上动态更改快速路由



我有一个使用nextjs的项目,并带有服务器端路由。

lib/routes/getPages

const routes = require('next-routes')();
const getEntries = require('../helpers/getEntries');
module.exports = async (app) => {
  const { items: [globalSetings] } = await getEntries({
    content_type: 'xxxxxxxx',
    include: 1,
    limit: 1,
  });
  routes
    .add('/', 'index')
    .add(`/${globalSettings.fields.blogSlug}/:slug`, 'blog');
  return routes.getRequestHandler(app);
};

server.js

const express = require('express');
const next = require('next');
const getPages = require('./lib/routes/getPages');
const app = next();
app.prepare().then(async () => {
  const server = express();
  const pageRoutes = await getPages(app);
  server.use(pageRoutes);
  server.listen(3000);
});

我从我的CMS API(在这种情况下很满足)的路线(例如博客部分)获得了sl。我想知道当应用程序已经运行时,如何处理管理员在CMS中更改sl。

猜测我需要重新启动应用程序的应用程序/工作路线。在这种情况下,我是否需要使用Webhook并收听CMS的更改,然后以某种方式以编程方式重新启动应用程序?这可能会起作用,但可能会增加开销。有更好的方法吗?

您可以使用解决方法来在Express中进行动态路由。这是我在打字稿应用中使用的内容:

  // https://github.com/expressjs/express/issues/2596
  let dynamicRouter: express.Router
  app.use(
    (req, res, next) => dynamicRouter(req, res, next),
  )
  function loadMyRoutes() {
    const newRouter = express.Router()
    const newMiddleware = // load my new middleware
    newRouter.use(newMiddleware)
    dynamicRouter = newRouter
  }

然后,您可以响应内容的Webhook致电loadMyRoutes()

app.post(`/webhook`, () => {
  loadMyRoutes()
})

相关内容

  • 没有找到相关文章

最新更新