【发布时间】:2019-08-10 22:16:33
【问题描述】:
抱歉,如果这是一个新手问题。我应该如何构建我的 REST API(我使用 Node 和 Express)。
const mongoose = require('mongoose');
const recipeSchema = mongoose.Schema({
_id: mongoose.Schema.Types.ObjectId,
name: {
type: String,
required: true
},
author: {
type: mongoose.Schema.Types.ObjectId,
ref: 'UserData',
required: true
},
description: String,
ingredients: [String],
steps: [String],
bookmarkNumber: Number,
likeNumber: Number,
rating: Number
})
module.exports = mongoose.model('Recipe', recipeSchema);
虽然我知道我可以将以下内容用于更大规模的功能,例如创建食谱和删除食谱等
router.get('/', (req, res, next) => {
// Get Recipes
});
router.post('/',checkAuth, (req, res, next) => {
// Create Recipe
});
router.get('/:recipeID', (req, res, next) => {
// Get Specific Recipe
});
但是,我目前被困在如何处理内部细节或特定资源上。例如:假设我想在配方中添加一个步骤。这个特定的实例是我可以放置动词的实例吗?我目前的想法是:
router.post('/:recipeID/steps',checkAuth, (req, res, next) => {
// Add Steps to recipeID if it exists
});
所以基本上为属性添加 url 并以这种方式处理它们,因为动词显然是 REST API 的罪过。
【问题讨论】:
-
您应该查看
Express 4.xAPI 参考。这真的很容易理解和很好的解释,在你的情况下,本节将解决你的疑惑:expressjs.com/en/4x/api.html#req -
首先,非常感谢您回答我的问题。我主要关心的更多是应该如何完成并遵循 Hateoas,因为我仍在尝试学习和掌握 REST API 结构。不过,我肯定会看一下 expressjs 文档。 restfulapi.net/hateoas.
标签: javascript node.js rest express api-design