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