- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我是 Node.js 新手,并且在 hapi.js 框架中构建了我的第一个 Node.js Restful API。所有服务所做的基本上都是数据库查询。服务的示例如下:
let myservice = {
method: "POST",
path: "/updateRule",
config: {
handler: (request, reply) => {
updateRule(request.payload)
.then((result) => {
reply(successResponse(request, result));
})
.catch((err) => reply(failResponse(request, err)).code(500));
},
validate: {
payload: {
ruleId: joi.number().required(),
ruleName: joi.string().required(),
ruleDesc: joi.string().required()
}
},
auth: "jwt",
tags: ["api", "a3i"]
},
}
updateRule(input): Promise<any> {
return new Promise((resolve, reject) => {
let query = `select a3i.update_rule(p_rul_id := ${input.ruleId}, p_rul_name := '${input.ruleName}', p_rul_desc := '${input.ruleDesc}')`;
postgresQuery(lbPostgres, query, (data, commit, rollback) => {
try {
let count = data.rows[0].update_rule.count;
if (count === 1) {
let ruleId = data.rows[0].update_rule.result[0];
let payload: SuccessPayload = {
type: "string",
content: `Rule ${ruleId} has been updated`
};
commit();
resolve(payload);
} else {
let thisErr = new Error("No rule can be found.");
thisErr.name = "4003";
throw thisErr;
}
}
catch (err) {
rollback();
if (err.name === "4003") {
reject(detailError(4003, err.message));
} else {
reject(detailError(4001, err.message));
}
}
}, reject);
});
}
正如您所看到的,当调用该服务时,它会引发数据库调用(查询)并更新数据库表中的指定行。同样,我还有其他名为 createRule/deleteRule 的服务,用于在数据库表中创建/删除记录。 在我看来,服务之间的区别在于执行不同的数据库查询。我读了这篇文章PUT vs. POST in REST但在我的例子中看不到 POST 和 PUT 的任何区别。
这是我的问题:
在这种情况下我应该使用什么 HTTP 方法?
大多数 Restful API 示例(例如 https://www.codementor.io/olatundegaruba/nodejs-restful-apis-in-10-minutes-q0sgsfhbd )使用相同的 URL 和不同的 HTTP 方法对同一“资源”执行不同的操作,在我看来,该资源通常是数据库表。与我的一个URL只有一种HTTP方法、只做一种操作的做法相比,这种架构有什么好处?
我知道这个问题不是指问题,也不具体。有些人可能会投反对票。但作为初学者,我真的想知道什么是典型的 Restful API,并确保我的 API 是“最佳实践”。请帮忙!
最佳答案
如果资源已存在,因此您有该资源的特定 URI 并且您想要更新它,则使用 PUT。
如果该资源尚不存在,而您想要创建它,并且您将让服务器选择代表该新资源的 URI,则使用 POST,并且 POST URI 将是通用的“创建新资源”URI,而不是特定资源的 URI,并且它将创建代表该资源的 URI。
如果调用者要创建代表新资源的资源 URI,您还可以使用 PUT 来创建新资源。在这种情况下,您只需 PUT 到该新资源,如果具有该 URI 的资源已存在,则会更新该资源,如果不存在,则会创建该资源。
您不必同时支持两者。您可以决定让您的 API 以仅使用其中之一的方式工作。
<小时/>在您的具体情况下,对数据库中已存在的特定行的更新几乎总是 PUT,因为它已经存在,因此您要对代表该行的特定 URI 执行 PUT。
What's the benefit of this architecture compared with my practice in which one URL only has one HTTP method and only do one type of operation?
这完全取决于您想要如何呈现您的 API。 REST 背后的一般概念是有几个组件:
resource identifier
data
method
在某些情况下,该方法可以包含在 GET、PUT、POST 或 DELETE 中,因此您只需要资源标识符、数据和 GET、PUT、POST 或 DELETE。
在其他情况或其他设计中,该方法比仅用 PUT 或 POST 表达的方法更详细,因此您实际上在 URL 中拥有一个方法,在这种情况下,您可能不需要那么区分 PUT 和 POST。
例如,操作可能是“购买”。虽然您可以在 URL 的其余部分隐含该方法的 POST 中捕获该信息,但为了清楚起见,您可能希望实际 POST 到其中包含方法的 URL:/buy
,然后您可以将相同的端点前缀与其他方法(例如 /addToCart
等)一起使用...这实际上取决于 REST 设计中的对象以及您想要在它们上显示的操作。有时,这些对象仅适用于 GET、PUT、POST 和 DELETE,有时,您希望 URL 中包含有关对该资源执行的特定操作的更多信息。
关于node.js - 构建 Restful API 时选择哪种 HTTP 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46800414/
我对编程真的很陌生,并且在理解 RESTful API 的概念时遇到了一些麻烦。我读过 REST 和 RESTful API。我已经查看了 SO 中已经提出的问题,但似乎无法更好地理解该主题。 在我的
我以为我知道REST /“RESTFul”,restfulservices,webservices,SOA和微服务是什么,但是我遇到了许多不同的定义,我得出的结论是这些术语被过度使用,滥用或完全错误定
我有一个列表,其中有一个“人员和组”列。当我使用 REST 查询行时,我会在此列中列出用户 ID。 我发现这篇文章将帮助我将每个 id 转换为标题 http://www.codeproject.com
我想问一些关于 REST 调用的问题。我是 REST 调用的绿色,我想了解什么是 REST 调用以及如何使用 URL 向服务器发送 REST 调用。谁能给我一些基本的教程或链接供我引用? 另外,如果我
很难说出这里问的是什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或言辞激烈,无法以目前的形式合理回答。如需帮助澄清此问题以便可以重新打开,visit the help center . 8年前关闭
如果有一个 REST 资源我想监视来自其他客户端的更改或修改,那么最好(也是最 RESTful)的方法是什么? 我这样做的一个想法是通过提供特定资源来保持连接打开,而不是在资源不(尚)存在时立即返回。
我有一个可以返回大量项目的 RESTful API,我希望能够使用分页样式技术来限制项目数量,这是 RESTful API 中的一个好主意吗? 如果有可能最好通过链接(在这种情况下为 url)或请求正
我仍然处于适应以 REST 方式做事的过程中。 在我的情况下,客户端软件将与 RESTful 服务交互。很少,客户端会上传其整个实体数据库(每个实体序列化为大约 5kb 的 xml 块)。 也许我错了
设计一个路径解析可能有歧义的 REST API 是否被认为是不好的做法?例如: GET /animals/{id} // Returns the animal with the given ID
我知道 REST 并且知道在不使用 session 的情况下创建 RESTful Web 服务,我更了解它,但我不太了解无状态的概念以及使用 REST 如何使您的应用程序可扩展 有人可以解释 REST
我正在尝试找到解决以下问题的最佳方法:我们的应用程序是SaaS,它支持Web登录的SAML。该应用程序还公开了应该在自动化和无人值守的流程中使用的REST API,这意味着没有交互式用户可以键入凭据。
由于 REST 是无状态的,因此传入的每个请求都不知道传入的前一个请求。在这种情况下是否可以使用连接池? 如果要实现连接池,它将像标准数据库连接一样在每个请求时打开连接池并关闭它。 如何实现 REST
得墨忒耳定律(真的应该是得墨忒耳的建议)说你不应该“穿过”一个物体去接触它们的子物体。如果您作为客户需要执行一些重要的操作,大多数情况下您使用的域模型应该支持该操作。 REST 原则上是一个愚蠢的对象
我唯一真正接触到 REST 的想法已经通过 Ruby on Rails 的 RESTful routing .这非常适合我使用 Rails 构建的基于 CRUD 的应用程序,但因此我对 RESTful
有什么好处 http://www.example.com/app/servlet/cat1/cat2/item 网址 超过 http://www.example.com/app/servlet?c
我知道以前有人问过这类问题。我有我的问题的解决方案,我想知道我是否在任何地方破坏了 REST 或 HTTP 主体。 在我的系统中,我有一个名为 member 的资源。支持通常的GET/POST/PUT
我有一个API,可以执行一些批量处理任务。假设它确实为某些资源命名。 我批量传递了7个请求,其中5个更新成功,2个失败。 我的问题是如何应对。使用HTTP时,我无法同时返回成功和错误。 有一个部分成功
我来自 RPC 世界,但目前正在调查使用 REST 是否适合我的项目。至于据我了解 Wikipedia RESTful 服务的基本思想是提供对集合及其各个元素的访问。 在我的情况下,服务器将是一个测量
我想将REST添加到我的挂毯项目中,因此需要知道如何实现它。 有什么更好的方法? 谢谢。 [编辑,从答案中复制:]我必须将GET,PUT,POST和DELETE服务添加到我的挂毯应用程序中。我看到Ta
让 /users/{id}成为 RESTful 服务中的资源 url。 启用基本身份验证,只有经过身份验证的用户才能访问该 url。 示例场景: User_1 & User_2是经过身份验证的用户,用
我是一名优秀的程序员,十分优秀!