- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
根据 this guide在设计 REST API 端点时,我们不应该在 URL 中使用 Action /动词(例如 /addNewEmployee
),如果我们想执行一个 Action ,我们应该只使用带有相应资源/名词的 HTTP 动词(例如 POST/employees
).
现在,我有一个名为 themes
的资源,我围绕它创建了以下端点:
GET/themes
(列出所有主题)
GET/themes/:name
(列出具有给定名称的单个主题)
我想创建另一个端点,通过它我可以执行一个操作(即切换主题),这个操作将更改数据库中 Settings
表中的 current_theme
字段值。我不确定这样做的最佳实践是 REST API 时尚,而且对消费者来说也是直观的。
我可以这样做 POST/themes/changeTheme
或 PUT/themes/:name/activate
但是 changeTheme
和 activate
是动词。我也可以执行此操作 PUT/settings
但从 API 使用者的角度来看,这似乎并不直观。请指导我在这种情况下应该如何进行。
最佳答案
According to this guide of designing REST API endpoints, we should never use action/verbs in URL
REST 不关心您使用什么拼写作为标识符。这是重点的一部分。 /e25928c5-7b4e-44b8-be83-24ed9c9f8d3b
是一个完美的精细标识符。
Stefan Tilkov对此进行了非常好的演讲。
Please guide me how should I proceed in such scenario.
想想您将如何使用网站。你会在某个页面上有一堆链接,其中一个链接上有一个标签,比如 changeTheme。您将单击该链接,并看到一个包含表单的新页面,其中包含可用主题列表。您将从列表中选择您想要的主题,然后提交表格。该请求将转到后端,更新一些资源。 副作用,您的主题记录将被更改。您可能会收到一条消息,告诉您已进行更改,并将您重定向回开始的位置。
这就是 REST。
因此,您要查找的名词 是集成域 中用于导航更改主题协议(protocol)的名词;换句话说,它们是表单和表单提交收件箱。
Jim Webber 将网络模型描述为 1950 年代的办公室;您可以通过检索表格、填写表格并将其放入收件箱来完成工作。
您想要的心理映射不是 Action (这太大胆了),而是请求——您正在发送消息询问其他人 采取您需要的行动。实际作用是副作用。所以“表单提交收件箱”是待处理的“更改主题”请求的集合。
对于此类事情,请使用本地的拼写约定。
远离资源代表您的域的想法;资源支持您的集成协议(protocol),并且资源的名称取自您的集成领域的语言,而不是您的业务领域的语言。
POST使用 unsafe semantics 发送请求几乎总是一个可接受的选择到服务器。请记住,我们在这里是因为网络有效,从a media type开始仅支持 GET 和 POST。
关于REST API 设计端点( Action /动词 => 名词/资源),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46677828/
我正在实现一个包装队列的 REST'ish API。我需要对项目进行入队和出队。通常我会使用 GET 来查询,但在这种情况下,将某些东西出队会通过删除该项目来改变状态。所以 GET 似乎是一个糟糕的选
我想将多个 Action 映射到单个HTTP动词,像这样 "/product"(controller: "product"){ action : [POST: ["save", "clone"] ]
我一直在努力坚持 the approved list of Powershell verbs命名我的 cmdlet 时。我有一个创建资源的函数,所以它被称为 New-ClearCaseView。我还想
我有一个 restful Controller ,我想使用 destroy 函数这是我的路线: +-------------------------------+------------------
好吧,我的目标是从文本中提取 NE(人称)和与其相关的动词。例如,我有这段文字: Dumbledore turned and walked back down the street. Harry Po
有点基础,但我已经尝试了一些方法来解决以下错误但无法得到正确的解决方案。
我有一个带有条件操作的资源: /foos/{id}/authorize /foos/{id}/cancel 这个想法是,授权会将资源的状态从已保存(默认)更改为已授权(由第三方应用程序)。授权可以从远
我经常有一种方法来验证特定值。在 powershell 中,约定是在“get-verb”列表中使用动词,但我不知道哪个最适合这种用法。 或者,如果我的设计架构应该更改以避免以其他方式通过方法进行验证,
我正在关注这件事:J Dictionary 它告诉我发出命令 d by d over d!/d 其中 d 是一个列表,但我的 jqt 环境告诉我 value 错误:结束。如果问题是我应该导入/安装/激
Sinatra 是否支持 OPTIONS HTTP 动词?就像是: options '/' do response.headers["Access-Control-Allow-Origin"] =
我需要发送数据并比较API服务器中是否存在。例如: $a['foo'] = 'hello'; $a['bar'] = 'world'; $rest->verb('resource', $a); 如果
我正在为服务器应用程序完成一组 cmdlet。应用程序的一部分包括安全主体管理和数据对象管理,以及两者的“到期”(定时和手动)。在到期日期之后,安全主体的登录和访问将被拒绝,并且可以选择阻止对该主体拥
通常单词列表是 1 个包含所有内容的文件,但是是否有可单独下载的名词列表、动词列表、形容词列表等? 我特别需要它们来学习英语。 最佳答案 如果您仅从 wordnet.princeton.edu/dow
我想创建一个函数,它将一个数据框和一个包含列名的字符向量作为输入,并以安全的方式在内部使用 tidy verse 引用函数。 我相信我有一个我想做的事情的例子。我想知道是否有更优雅的解决方案或者我错误
使用 ShellExecute API,您可以指定一个动词,例如“打开”或“打印”。是否可以从命令行执行相同的操作? 最佳答案 http://www.naughter.com/shelexec.htm
在我的网站“联系我们”页面中有一个查询表单,当我提交该表单时,它会收到错误消息 405 - HTTP verb used to access this page is not allowed. The
我正在使用斯坦福解析器进行词性标记,我想从标记器所做的标记中获取名词、形容词动词、副词的单独同义词集。例如 如果我的输入查询是 “恒河是印度最大的河流,人们过去将它视为神” 标记器的输出是: “恒河/
我正在用 Python 构建一个非常简单的 REST 服务。它所做的只是接收一个 JSON 字符串,对其应用算法并发回 JSON 字符串响应。我了解 GET、POST、PUT 和 DELETE 之间的
我正在从事机器翻译项目。我需要确定句子的主语、动词、宾语才能继续我的工作。目前我正在使用斯坦福 NLP 解析器来分析句子。但我不知道如何提取 SVO。有什么我可以考虑的想法吗? 最佳答案 如果你想实现
我正在编写一个 REST 网络服务,将文本从一种语言翻译成另一种语言。文本可能相当大,最多可达几兆字节。 什么 HTTP 动词最适合使用? 我的第一个想法是使用 GET,因为它获取给定文本的翻译。但是
我是一名优秀的程序员,十分优秀!