Skip to main content

示例手册:自定义路由

🌐 Examples cookbook: Custom routes

🏗 Work in progress

此页面的内容可能尚未与 Strapi 5 完全同步。

🌐 The content of this page might not be fully up-to-date with Strapi 5 yet.

Prerequisites

此页面是后端自定义示例手册的一部分。请确保你已阅读其介绍

🌐 This page is part of the back end customization examples cookbook. Please ensure you've read its introduction.

💭 上下文:

开箱即用时, FoodAdvisor 不会控制对其内容类型端点的访问。

假设我们之前创建了一个策略来限制对“评论”内容类型的访问某些条件,例如防止餐厅老板为他们的餐厅创建评论。我们现在必须在用于创建评论的路由上启用该策略。

🌐 Let's say we previously created a policy to restrict access to the "Reviews" content-type to some conditions, for instance to prevent a restaurant's owner to create a review for their restaurants. We must now enable the policy on the route we use to create reviews.

🎯 目标:

  • 明确定义“Reviews”内容类型的路由配置。
  • 将创建评论时使用的路由配置为:
🤓 相关概念

更多信息可以在政策路线文档中找到。

🌐 Additional information can be found in the Policies and Routes documentation.

🧑‍💻 代码示例:

FoodAdvisor 项目的 /api 文件夹中,将 api/src/api/review/routes/review.js 文件的内容替换为以下代码:

src/api/review/routes/review.js

'use strict';

const { createCoreRouter } = require('@strapi/strapi').factories;

module.exports = createCoreRouter('api::review.review', {
config: {
create: {
auth: false, // set the route to bypass the normal Strapi authentication system
policies: ['is-owner-review'], // set the route to use a custom policy
middlewares: [],
},
},
});

What's next?

了解更多关于如何配置自定义中间件以执行扩展你的 Strapi 应用的附加操作的信息。

🌐 Learn more about how to configure custom middlewares to perform additional actions that extend your Strapi-based application.