gpt4 book ai didi

c# - 数据集返回意外结果的 JsonConvert.serializeObject

转载 作者:太空宇宙 更新时间:2023-11-03 22:50:50 25 4
gpt4 key购买 nike

我正在尝试将数据集转换为 .net core 2.0 中的 JSON,并使用以下代码来执行此操作

return Ok(JsonConvert.SerializeObject(dataset, Formatting.Indented))

我得到的输出是

"{\n \"DataSet.RemotingVersion\": {\n \"Major\": 2,\n \"Minor\": 0,\n \"Build\": -1,\n \"Revision\": -1,\n \"MajorRevision\": -1,\n \"MinorRevision\": -1\n },\n \"XmlSchema\": \"<?xml version=\\\"1.0\\\" encoding=\\\"utf-16\\\"?>\\n<xs:schema id=\\\"dataset\\\" xmlns=\\\"\\\" xmlns:xs=\\\"http://www.w3.org/2001/XMLSchema\\\" xmlns:msdata=\\\"urn:schemas-microsoft-com:xml-msdata\\\">\\n <xs:element name=\\\"dataset\\\" msdata:IsDataSet=\\\"true\\\" msdata:UseCurrentLocale=\\\"true\\\">\\n <xs:complexType>\\n <xs:choice minOccurs=\\\"0\\\" maxOccurs=\\\"unbounded\\\">\\n <xs:element name=\\\"datatable\\\">\\n <xs:complexType>\\n <xs:sequence>\\n <xs:element name=\\\"cvbf\\\" type=\\\"xs:string\\\" msdata:targetNamespace=\\\"\\\" minOccurs=\\\"0\\\" />\\n </xs:sequence>\\n </xs:complexType>\\n </xs:element>\\n </xs:choice>\\n </xs:complexType>\\n </xs:element>\\n</xs:schema>\",\n \"XmlDiffGram\": \"<diffgr:diffgram xmlns:msdata=\\\"urn:schemas-microsoft-com:xml-msdata\\\" xmlns:diffgr=\\\"urn:schemas-microsoft-com:xml-diffgram-v1\\\" />\"\n}"

我是 C# 开发的新手,

  • 如何将其转换成合适的 JSON?
  • 为什么会这样?

最佳答案

这里有两个问题:

  1. 您似乎在双重序列化您的 datasetJSON.NET Parser seems to be double serializing my objects 中描述的方式.首先,您手动将返回的对象序列化为字符串,然后调用 Ok(object) 序列化传入的对象(即 JSON 字符串),从而导致嵌套序列化。

    解决方案是不这样做。让框架为您序列化您的对象,只需执行 return Ok(dataset);

  2. 更新。 Json.NET 11.0 Release 1支持 .NET Standard 2.0,因此序列化为 DataSetDataTable现在可以在 .Net 核心中使用此版本和更高版本。您需要升级到此版本或后续版本。

    原始答案。您的第二个问题是您正在尝试序列化 DataSet在 .Net 核心中使用 Json.NET 使用 Json.NET 10.0.3或更早 - 不幸的是,尚不支持这样做。如 Issue #1409: serializes a DataSet to JSON on dotnet core 2.0 中所述和 Issue #1383: .Net core build doesn't include DataTableConverter ,此版本的 Json.NET 以 netstandard 1.3 为目标,而 DataSetDataTable在 netstandard 1.5 中引入。因此,此版本没有在 .Net 核心中序列化这些类型的内置逻辑。

    那么,您使用这个版本有哪些选择?首先,Json.NET 在 MIT License 下获得许可。所以你可以复制它的版本 DataSetConverter DataTableConverter ,将它们包含在您的项目中,并将它们添加到 JsonSerializerSettings.Converters .问题JsonSerializerSettings and Asp.Net Core展示了如何在 ASP.NET Core 中自定义设置。

    其次,您可以转换您的 DataSetDTO并返回它。例如,以下扩展方法转换任何 DataSetDictionary<string, List<Dictionary<string, object>>> ,可由 Json.NET 序列化:

    public static class DataSetExtensions
    {
    public static List<Dictionary<string, object>> ToDictionaryList(this DataTable table)
    {
    if (table == null)
    return null;
    return table.Rows.Cast<DataRow>()
    .Select(r => table.Columns.Cast<DataColumn>().ToDictionary(c => c.ColumnName, c => r[c]))
    .ToList();
    }

    public static Dictionary<string, List<Dictionary<string, object>>> ToDictionary(this DataSet set)
    {
    if (set == null)
    return null;
    return set.Tables.Cast<DataTable>()
    .ToDictionary(t => t.TableName, t => t.ToDictionaryList());
    }
    }

    更好的是,创建一个强类型模型来返回。 (如果您还序列化为 XML,那么这是更好的解决方案,因为 XmlSerializer 不支持字典的序列化。)

关于c# - 数据集返回意外结果的 JsonConvert.serializeObject,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47392643/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com