- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在尝试 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="fcd2bc8f999d8e9f94d294959b9490959b94888f" 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="365d54625f425a5376595257425718424f4653" 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="f19a93a598859d94b19e95908590df85888194" 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/
我一直在尝试 Azure 最近发布的搜索服务,并使用 JSON.Net 将生成的 JSON 输出转换为 XML。它通常工作正常,除了添加突出显示参数时我得到 Cannot get an XML str
我一直在尝试 Azure 最近发布的搜索服务,并使用 JSON.Net 将生成的 JSON 输出转换为 XML。它通常工作正常,除了添加突出显示参数时我得到 Cannot get an XML str
我有以下 C# WebClient 返回的 JSON: "\n\n\n{\n \"resultCount\":1,\n \"results\": [\n{\"wrapperType\":\"artis
我正在解析 JSON,但出现以下错误: 我正在使用 Newtonsoft.Json.NET dll。 Error reading string. Unexpected token: StartObje
我有一个有效的 json(任何 json 字符串)字符串并尝试将其转换为数据集,但 Newtonsoft.Json 未能这样做。 JSON文本: {"root": { "Item": [
我正在尝试批量创建ElasticSearch中已经存在的文档。 descriptor.Create(op => op.Document((D)baseNotice)); _elasticCli
我正在尝试使用 Web API 将实体添加到 Dynamics 2016 On Premise。该实体引用了其他三个实体。当我尝试发布实体时,我收到以下错误。 An unexpected 'Start
我是一名优秀的程序员,十分优秀!