我正在使用newton的json.net序列化程序。将json反序列化为'TheFox'时;它进入受保护的ctor并获取默认属性值。但不是json字符串中的属性值。我可以在不使用dto或任何其他映射框架的情况下解决这个问题吗?
class TheFox
{
string _Id;
string _Name;
protected TheFox()
{
_Id = "Default Id";
_Name = "Default Name";
}
public TheFox(string id, string name) : this()
{
_Name = name;
_Id = id;
}
public string Id
{
get { return _Id; }
}
public string Name
{
get { return _Name; }
}
}
这是测试:
var fox = new TheFox("FoxId", "FoxTail");
var json = JsonConvert.SerializeObject(fox);
Console.WriteLine(json);
var settings = new JsonSerializerSettings ()
{
ConstructorHandling = ConstructorHandling.AllowNonPublicDefaultConstructor
};
var returned = JsonConvert.DeserializeObject<TheFox> (json, settings);
Assert.IsTrue (returned.Id != "Default Id");
Assert.IsTrue (returned.Name != "Default Name");
答案 0 :(得分:0)
class TheFox
{
string _Id;
string _Name;
protected TheFox() : this("Default Id", "Default Name")
public TheFox(string id, string name)
{
_Name = name;
_Id = id;
}
public string Id
{
get { return _Id; }
}
public string Name
{
get { return _Name; }
}
}
这应该允许相同的用法,但提供与牛顿的可比性。
答案 1 :(得分:0)
检查了json.net的来源,现在没办法了。因为如果给定属性是只读的,它会跳过设置值阶段。可能需要内部字段填充功能。
private void SetPropertyValue(JsonProperty property, JsonReader reader, object target)
{
// bla.. bla.. bla..
if (!property.Writable && !useExistingValue)
{
reader.Skip();
return;
}
该方法很糟糕,它需要一个实例化的对象来填充,但它可以工作。
var a = new TheFox("x", "y");
var json = JsonConvert.SerializeObject(a);
Console.WriteLine(json);
var returned = JsonConvert.DeserializeAnonymousType(json, new TheFox("q", "a"));
Assert.That(a.Id, Is.EqualTo(returned.Id));
Assert.That(a.Name, Is.EqualTo(returned.Name));
答案 2 :(得分:-2)
您的课程不适合客户端操作。您需要将DataContractAttribute用于要序列化的成员的类和DataMemberAttribute属性。