我有一个使用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()
})