这是一个从android设备获取请求的WCF服务。相同的请求在棒棒糖设备上有效,而在软糖设备上无效,因为软糖在创建时对JSON的排列方式不同。
例外:
反序列化对象时出现意外标记:字符串。路径"SearchFilters.config.$type",第1行,位置212。
不工作Json:
{
"DeviceType": 2,
"SearchFilters": {
"config": {
"$values": [
{
"Collection": {
"DeviceType": 2
},
"Category": ""
}
],
"$type": "System.Collections.Generic.List`1[[Yoosh.SharedClasses.YooshConfig, YooshSharedClassesDll]], mscorlib"
}
},
"RequestingUserId": "66666666-6666-6666-6666-666666666666",
"APIKey": "xxx"
}
工作Json:
{
"APIKey": "xxx",
"DeviceType": 2,
"RequestingUserId": "66666666-6666-6666-6666-666666666666",
"SearchFilters": {
"config": {
"$type": "System.Collections.Generic.List`1[[Yoosh.SharedClasses.YooshConfig, YooshSharedClassesDll]], mscorlib",
"$values": [
{
"Category": "",
"Collection": {
"DeviceType": 2
}
}
]
}
}
}
有些字段的顺序不同。。这是唯一的区别。
C#类:
public class QueryParameters
{
BaseParameters m_baseParameters;
Guid m_gRequestingUserId;
Dictionary<string, object> m_SearchFilters;
[DataMember]
public string APIKey
{
get { return m_baseParameters.APIKey; }
set { m_baseParameters.APIKey = value; }
}
[DataMember]
public BaseParameters.YooshDeviceType DeviceType
{
get { return m_baseParameters.DeviceType; }
set { m_baseParameters.DeviceType = value; }
}
[DataMember]
public string DeviceId
{
get { return m_baseParameters.DeviceId; }
set { m_baseParameters.DeviceId = value; }
}
[DataMember]
public Guid RequestingUserId
{
get { return m_gRequestingUserId; }
set { m_gRequestingUserId = value; }
}
[DataMember]
public Dictionary<string, object> SearchFilters
{
get { return m_SearchFilters; }
set { m_SearchFilters = value; }
}
}
Json.net版本:6.0.8
设置JsonSerializerSettings.MetadataPropertyHandling = MetadataPropertyHandling.ReadAhead
。
根据文件:
此示例反序列化JSON,MetadataPropertyHandling设置为ReadAhead,这样元数据属性就不需要位于对象的开头。
string json = @"{ 'Name': 'James', 'Password': 'Password1', '$type': 'MyNamespace.User, MyAssembly' }"; object o = JsonConvert.DeserializeObject(json, new JsonSerializerSettings { TypeNameHandling = TypeNameHandling.All, // $type no longer needs to be first MetadataPropertyHandling = MetadataPropertyHandling.ReadAhead });
请注意,此设置将影响性能。
最后,当使用TypeNameHandling
时,请注意Newtonsoft文档中的注意事项:
当应用程序从外部源反序列化JSON时,应谨慎使用TypeNameHandling。当使用None以外的值进行反序列化时,应使用自定义SerializationBinder验证传入类型。
有关为什么需要这样做的讨论,请参阅Newtonsoft Json中的TypeNameHandling小心事项。