c# - 无法从 token 类型 'StartObject' 获取 XML 字符串值

标签 c# xml json azure json.net

我一直在尝试 Azure 最近发布的搜索服务,并使用 JSON.Net 将生成的 JSON 输出转换为 XML。它通常工作正常,除了添加突出显示参数时我得到 Cannot get an XML string value from token type 'StartObject'. Path 'value[0]<a href="https://stackoverflow.com/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="b799f7c4d2d6c5d4df99dfded0dfdbded0dfc3c4" rel="noreferrer noopener nofollow">[email protected]</a>'错误信息。高亮参数添加 @search.highlights解析器似乎不喜欢它。我还检查了 jsonvalidatortool.com 上的 JSON 输出,结果是有效的。

从 Azure 搜索服务收到的 JSON 如下:

{
  "value":
    [
      {
        "@search.score": 1.2591839,
        "@search.highlights": 
          {
            "<a href="https://stackoverflow.com/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="442f26102d302821042b202530256a303d3421" rel="noreferrer noopener nofollow">[email protected]</a>": "#Collection(String)",
            "kbTitle": [
              "No Video / Blank Screen When Attempting to Stream from <em>Netflix</em>"
            ]
          },
        "kbID":"10",
        "kbTitle":"No Video / Blank Screen When Attempting to Stream from Netflix"
      }
    ]
}

还有其他人尝试使用 JSON.Net 的新 Azure 搜索服务并遇到此问题吗?

最佳答案

不幸的是,这个 JSON 虽然有效,但无法通过 Json.Net 直接转换为 XML,原因有两个:

  1. 当 JSON.Net 看到以 @ 开头的 JSON 属性名称时,它尝试将其转换为 XML 中的属性。 XML 属性必须是简单值(字符串、整数等);它不可能是一个复杂的对象。在 JSON 中,@search.highlights 的值property 显然是一个复杂的对象,因此它无法转换为 XML 属性。这就是您收到错误的原因。

  2. XML 标记名称不能包含 @ 。假设我们能够解决第一个问题(例如,通过从 @ 中删除前导 @search.highlights ),当尝试转换 <a href="https://stackoverflow.com/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="39525b6d504d555c79565d584d58174d40495c" rel="noreferrer noopener nofollow">[email protected]</a> 时,将会抛出另一个错误。属性到 XML 标记中,因为它包含 @在中间。

我想到了一些可能的解决方案:

快速而肮脏的方法是在将 JSON 转换为 XML 之前尝试对其进行字符串替换。如果问题区域只是我突出显示的这两个特定属性名称,那么您可以专门针对它们来删除或替换 @带有更适合 XML 的字符,如下划线 _ 。如果 JSON 更加动态,导致问题属性名称高度可变,则此方法不太可能正常工作。您比我更了解您的数据 - 我对 Azure 搜索服务不太熟悉。

更可靠的解决方案是将 JSON 反序列化为 JObject ,然后手动遍历JObject并按照您需要的方式将其转换为 XML。您可以省略不需要的部分,更改属性/标签名称等。当然,这假设您熟悉 Json.Net 的 LINQ-to-JSON API (JObject、JTokens、JArrays 等)并且能够轻松使用 System.Xml namespace 中的类在.NET框架中。

另一个想法是创建一个中间模型类,将 JSON 反序列化为该类(这样您就可以使用 [JsonProperty] 属性来处理时髦的属性名称),然后使用 XmlSerializer 将该模型转换为 XML。

希望这有帮助。

关于c# - 无法从 token 类型 'StartObject' 获取 XML 字符串值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25537687/

相关文章:

android - 具有折叠工具栏和 ImageView 的视差 TabLayout

java - 在 Java 中解析 XML 时出现问题

javascript - 访问 .json 文件中的字段

json - RestSharp反序列化JSON内容(表示一个对象包含一个字节数组)错误

python - 如何将提取的数据转换成python字典?

c# - Stored proc输出参数+Select不传回输出参数

c# - 是否有生产级 SimpleDB .NET 库?

Java使用dom删除xml节点

c# - 如何为 C# Windows 应用程序创建自动更新

C# : error using if/switch : "Local variable already defined in this scope"