gpt4 book ai didi

rest - 如何在 RESTful ASP.NET Web API 中路由非 CRUD 操作?

转载 作者:行者123 更新时间:2023-12-03 23:49:25 25 4
gpt4 key购买 nike

我正在尝试使用 ASP.NET Web API 为我们的服务设计一个 RESTful Web API。我在弄清楚如何将非 CRUD 操作路由到正确的 Controller 操作时遇到了麻烦。假设我的资源是一扇门。我可以用我的门做所有熟悉的 CRUD 事情。假设我的门的模型是:

public class Door
{
public long Id { get; set; }
public string InsideRoomName { get; set; }
public string OutsideRoomName { get; set; }
}

我可以通过我的 web api 完成所有标准的 CRUD 操作:
POST: http://api.contoso.com/v1/doors
GET: http://api.contoso.com/v1/doors
GET: http://api.contoso.com/v1/doors/1234
GET: http://api.contoso.com/v1/doors?InsideRoomName=Cafeteria
PUT: http://api.contoso.com/v1/doors/1234
DELETE: http://api.contoso.com/v1/doors/1234

等等。我遇到麻烦的地方是当我需要对我的门进行非 CRUD 操作建模时。我想对我的资源建模一个 Lock 和 Unlock 动词。通读 ASP.NET articles该指南似乎是在使用自定义操作时切换到 RPC 样式调用。这给了我一条路径:
PUT: http://api.contoso.com/v1/doors/1234/lock
PUT: http://api.contoso.com/v1/doors/1234/unlock

这似乎与旨在指示资源的路径的 REST 精神相冲突。我想我可以将动词建模为资源:
POST: http://api.contoso.com/v1/doors/1234/lockrequests
POST: http://api.contoso.com/v1/doors/1234/unlockrequests

在这种情况下,我仍然可以使用推荐的 {controller}/{id}/{action} 但似乎我仍在创建混合 RPC/REST API。就 REST 接口(interface)而言,是否有可能,甚至推荐将自定义操作放在参数列表中?
PUT: http://api.contoso.com/v1/doors/1234?lock
PUT: http://api.contoso.com/v1/doors/1234?unlock

我可以预见到需要使用查询参数支持此调用,例如:
PUT: http://api.contoso.com/v1/doors?lock&InsideRoomName=Cafeteria

我将如何创建将这个请求映射到我的 DoorsController 的路由?
public class DoorsController : ApiController
{
public IEnumerable<Doord> Get();
public Door Get(long id);
public void Put(long id, Door door);
public void Post(Door door);
public void Delete(long id);

public void Lock(long id);
public void Unlock(long id);
public void Lock(string InsideRoomName);
}

关于 REST API 设计方面什么是最佳实践,什么不是最佳实践,我可能在这里做出了一些错误的假设,因此也欢迎任何指导。

最佳答案

从 RESTful 原则来看,也许最好引入一个“状态”属性来管理那些非 CURD 操作。但我认为它不符合真正的生产发展。

对这类问题的每一个答案,看起来您都必须使用变通方法来强制您的 API 设计符合 RESTful。但我担心的是,这真的给用户和开发者都带来了便利吗?

我们来看看谷歌博主API3.0的设计:https://developers.google.com/blogger/docs/3.0/reference ,它使用很多 URL 进行非 CURD 操作。

这很有趣,

POST  /blogs/blogId/posts/postId/comments/commentId/spam

描述是

Marks a comment as spam. This will set the status of the comment to spam, and hide it in the default comment rendering.



您可以看到,评论有一个状态来指示它是否是垃圾邮件,但它的设计不像 JoannaTurban 上面提到的答案。

我认为从用户的角度来看,它更方便。不需要关心“状态”的结构和枚举值。实际上你可以在“状态”的定义中加入很多属性,比如“isItSpam”、“isItReplied”、“isItPublic”等。如果状态有很多东西,设计就会变得不友好。

在某些业务逻辑要求上,使用易于理解的动词,而不是试图使其完全成为“真正的”RESTful,它对用户和开发人员来说都更有效率。这是我的意见。

关于rest - 如何在 RESTful ASP.NET Web API 中路由非 CRUD 操作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16091947/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com