2

我正在评估 ServiceStack 作为我们想在我们的系统环境中使用的可能的 REST 服务,到目前为止我对它非常满意。对服务的要求是隐藏特定用户或用户组的字段。根据密钥/会话,用户不会将数据模型的所有字段都返回给客户端,它们必须被服务堆栈隐藏。因此,在从 Linq2SQL 接收到数据对象(列表)后,我使用反射分析对象,提取对象成员,忽略应该隐藏的成员并将其他成员添加到字典中。之后,我将字典传递给 ServiceStack,ServiceStack 将其序列化并将数据结构发送给客户端。

我对此设置的问题是:

  • 这是使用 ServiceStack 的正确方法还是我滥用了一个很快就会修复的漏洞?
  • 有没有一种 ServiceStack 方法可以实现相同的目标?
  • 您可以推荐任何最佳做法吗?
4

1 回答 1

3

使用 ServiceStack 的正确方法是为您的 API 定义 DTO,而不是尝试使用现有的业务对象。如果您的客户准备解析返回具有字典属性的 DTO 的列表,则可以工作。

一种“ServiceStack”方法是定义一个简单的、平面的、具有所有可能属性的 DTO,其中每个属性都是可空的。

给定 DTO 定义如下:

public class NullablePartials
{
    public Int32? Test1 { get; set; }
    public String Test2 { get; set; }
    public Double? Test3 { get; set; }
}

以下片段:

Dictionary<String, String> MyDtoDictionary = new Dictionary<String, String>();
MyDtoDictionary.Add("Test1", "7");
MyDtoDictionary.Add("Test2", "Value2");
NullablePartials result = MyDtoDictionary.ToJson().FromJson<NullablePartials>();

System.Diagnostics.Debug.WriteLine(MyDtoDictionary.ToJson());
System.Diagnostics.Debug.WriteLine(result.ToJson());

产生:

{"Test1":"7","Test2":"Value2"}
{"Test1":7,"Test2":"Value2"}

在默认设置中使用 ServiceStack.Text 作为 JSON 库来序列化空值。

至于最佳实践,请参阅https://github.com/ServiceStack/ServiceStack/wiki/Advantages-of-message-based-web-services,其中讨论了 ServiceStack 理念。特别推荐使用:

代码优先 POCO

由于它提倡干净、可重用的代码,ServiceStack 一直鼓励在几乎所有事情上使用代码优先的 POCO。即可以使用相同的 POCO:

  • 在请求和响应 DTO 中(在客户端和服务器上)
  • 在 JSON、JSV 和 CSV 文本序列化器中
  • 作为 OrmLite、db4o 和 NHibernate 中的数据模型
  • 作为存储在 Redis 中的实体
  • 作为存储在缓存和会话中的 blob
  • 在 MQ 的服务中删除并执行
  • 将复杂的构型脱水成

利用围绕 POCO 构建功能的不同技术提供了前所未有的重用水平,减少了摩擦,促进了一致、更可用和更容易解释代码库。

于 2013-10-02T15:05:10.660 回答