3

我正在尝试保存(RavenDB build 960)通过其内置传递到 Nancy 模块的表单数据项的名称和值Request.Form

如果我保存一个简单的dynamic对象实例(带有测试属性和值),那么一切正常,并且属性名称和值都被保存。但是,如果我使用 Nancy 的Request.Form,则只保存动态属性名称。

我知道在检索动态数据(RavenJObjects 等)时,我将不得不处理与恢复正确类型有关的进一步问题,但现在,我想首先解决保存动态名称/值的问题。

这是整个测试请求和代码:

提琴手请求 (PUT) 在此处输入图像描述

南希模块

Put["/report/{name}/add"] = parameters =>
    {
        reportService.AddTestDynamic(Db, parameters.name, Request.Form);
        return HttpStatusCode.Created;
    };

服务

public void AddTestDynamic(IDocumentSession db, string name, dynamic data)
{
    var testDynamic = new TestDynamic
    {
            Name = name,
            Data = data
    };
    db.Store(testDynamic);
    db.SaveChanges();
}

测试动态类

public class TestDynamic
{
    public string Name;
    public dynamic Data;
}

Request.Form 在运行时的动态内容 在此处输入图像描述

生成的 RavenDB 文档

{
  "Name": "test",
  "Data": [
    "username",
    "age"
  ]
}

注意: Request.Form 的类型是Nancy.DynamicDictionary。我认为这可能是问题所在,因为它继承自IEnumerable<string>而不是预期的IEnumerable<string, object>. 我认为 RavenDB 正在枚举DynamicDictionary并且只取回动态成员名称而不是成员名称/值对。

谁能告诉我如何或是否可以将 Request.Form 视为一个dynamic对象,以将其保存到 RavenDB?如果可能的话,我想避免任何手工枚举DynamicDictionary来构建dynamic实例,以便 RavenDB 可以正确序列化。

谢谢你

编辑 1 @Ayende

DynamicDictionary 似乎实现了该GetDynamicMemberNames()方法:

南希动态词典

查看 GitHub 上的代码可以发现以下实现:

public override IEnumerable<string> GetDynamicMemberNames()
{
    return dictionary.Keys;
}

这是您希望在这里看到的吗?

编辑 2 @TheCodeJunkie

感谢代码更新。为了测试这一点,我有:

  1. 从 GitHub 创建了 NancyFx/Nancy 主分支的本地克隆
  2. 将 Nancy.csproj 添加到我的解决方案中并引用了该项目
  3. 运行与上面相同的测试

来自新 DynamicDictionary 的 RavenDB 文档

{
  "Name": "test",
  "Data": {
    "$type": "Nancy.DynamicDictionary, Nancy",
    "username": {},
    "age": {}
  }
}

您可以看到生成的文档是一个改进。DynamicDictionaryRavenDB 现在可以正确获取类型信息,并且虽然动态属性名称已正确序列化,但不幸的是动态属性值没有。

下图显示了新的外观DynamicDictionary。对我来说一切都很好,新的字典界面清晰可见。我唯一注意到的是调试器中的动态“结果视图”(与“动态视图”相反)只显示属性名称而不是它们的值。“动态视图”和以前一样显示(见上图)。

DynamicDictionary 在运行时的内容 在此处输入图像描述

4

1 回答 1

1

生物分形,问题是动态字典,在 JSON 中,类型可以是对象或列表,它们不能同时是。对于动态对象序列化,我们依靠 GetDynamicMemberNames() 的实现来获取属性,我认为不存在。

于 2012-06-25T07:34:50.740 回答