使用正确的类型从JsonConvert.SerializeXNode返回json

时间:2014-12-29 09:10:28

标签: c# xml json serialization json.net

var test = new
            {
                TestStr = "test",
                TestNumber = 123,
                TestDate = new DateTime(1986, 1, 13, 17, 50, 31),
                TestBool = true
            };

var xml = JsonConvert.DeserializeXNode(JsonConvert.SerializeObject(test), "test");

此代码返回不错的xml元素:

<test>
  <TestDate>1986-01-13T14:50:31Z</TestDate>
  <TestBool>true</TestBool>
  <TestNumber>123</TestNumber>
  <TestStr>test</TestStr>
</test>

当我尝试将此xml转换回JSON

var json = JsonConvert.SerializeXNode(xml, Formatting.None, true);

我只使用String属性获取JSON。

如何让json获得合适的类型呢?

1 个答案:

答案 0 :(得分:3)

JSON和XML是不同的序列化格式,具有不同的功能。 JSON可以区分stringnumberboolean,而XML会将所有内容视为字符串。因此,当您从JSON转换为XML并返回时,类型信息会丢失。处理此问题的一种方法是在来回转换时使用强类型中间模型。换句话说,不是直接从XML转换为JSON,而是将XML反序列化为模型,然后将模型序列化为JSON。该模型将强制数据为正确的类型。

以下是一个例子:

class Program
{
    static void Main(string[] args)
    {
        string xml = @"
        <test>
          <TestDate>1986-01-13T14:50:31Z</TestDate>
          <TestBool>true</TestBool>
          <TestNumber>123</TestNumber>
          <TestStr>test</TestStr>
        </test>";

        XmlSerializer ser = new XmlSerializer(typeof(Test));
        Test test = (Test)ser.Deserialize(new StringReader(xml));
        string json = JsonConvert.SerializeObject(test, Formatting.Indented);
        Console.WriteLine(json);
    }
}

[XmlType("test")]
public class Test
{
    public string TestStr { get; set; }
    public int TestNumber { get; set; }
    public DateTime TestDate { get; set; }
    public bool TestBool { get; set; }
}

输出:

{
  "TestStr": "test",
  "TestNumber": 123,
  "TestDate": "1986-01-13T14:50:31Z",
  "TestBool": true
}