我正在尝试找出构建API的最佳方法;我们在标准REST结构中设置了评论(列表一,列出所有,创建,更新等) . 如果它不完全适合的例子是:每个评论可以链接到一个或多个其他类型,例如事件,位置或事物 .
我的想法是网址将是:/ event / reviews /(或相反的例如/ reviews / event /)/ location / reviews / / thing / reviews /
然而,我可以看到的问题是每个这样的“GET”应该返回父对象,即一个事件 .
那么使用ServiceStack,处理这种情况的最佳方法是什么?是为每个数据请求创建一个自定义服务而不是滥用开箱即用的REST设置还是我错过了一些更基本的东西?
2 回答
首先,“最佳”解决方案是一个相当主观的术语 . 我通常的目标是干燥,可重复使用,高性能的解决方案,促进最小的努力,摩擦和chattiness,而其他人可能会定义“最佳”,它遵循REST的原则 . 因此,根据目标的不同,您将获得不同的响应 . 我只能提供如何处理它 .
ServiceStack服务实现从其自定义路由中解耦
需要记住的一件事是,您在ServiceStack中定义和设计服务的方式与您公开它们的方式完全脱离,因为您可以在任何自定义路径下公开您的服务 . ServiceStack鼓励基于消息的设计,因此您应该为每个操作提供不同的消息 .
使用逻辑/分层Url结构
我使用逻辑Url结构,我的目标是表示名词的标识符,它是分层结构的,即父路径对您的资源进行分类并为其提供有意义的上下文 . 因此,在这种情况下,如果您想公开事件和评论,我倾向于使用以下url结构:
这些资源标识符中的每一个都可以应用任何HTTP谓词
实施
对于实现,我通常遵循基于消息的设计,并基于响应类型和调用上下文对所有相关操作进行分组 . 为此我会做类似的事情:
并按照类似的模式进行活动评论
基于这些消息,实现应该是相当直接的,这些消息(取决于代码库大小)我将在2 EventsService 和 EventReviewsService 类中组织 . 我应该注意,我自己使用多个服务请求DTO名称,以避免与同名的数据模型发生冲突 .
虽然我已将
UpdateEvent
和CreateEvent
分开,但如果用例允许,我有时会将它们合并为单个幂等StoreEvent
操作 .物理项目结构
理想情况下,根级 AppHost 项目应保持轻量级且无实现 . 虽然对于只有少量服务的小型项目,可以将所有内容都放在一个项目中,并根据需要简单地扩展您的架构 .
对于中型到大型项目,我们建议使用下面的物理结构,为了本示例的目的,我们假设我们的应用程序名为 EventMan .
项目的顺序也显示其依赖性,例如顶级
EventMan
项目引用 all 子项目,而最后一个EventMan.ServiceModel
项目引用 none :随着
EventMan.ServiceModel
DTO 's kept in their own separate implementation and dependency-free dll, you'可以自由地在任何.NET客户端项目中共享此dll - 您可以将其与任何通用C# Service Clients一起使用,以提供没有任何代码生成的端到端类型API .更新
此建议的项目结构现在包含在所有ServiceStackVS' VS.NET Templates中 .
Simple Customer REST Example有一个小型的自包含,真实世界的例子,用于使用RDBMS创建简单的REST服务 .
不确定它是否有助于你的场景/理解,但我觉得这个演示文稿很有帮助:
Designing a Beautiful REST+JSON API