我正在使用一个私有的Web服务,这不在我的控制范围内。
我正在使用登录服务,这是即将取消结果的类
[DataContract]
public class BaseDTO
{
[DataMember]
public string status { get; set; }
[DataMember]
public string msg { get; set; }
[DataMember]
public string code { get; set; }
[DataMember(Name = "data", IsRequired = false)]
public LoginDTO LoginInfo{ get; set; }
}
[DataContract]
public class LoginDTO
{
[DataMember]
public string FirstName{ get; set; }
[DataMember]
public string LastName{ get; set; }
}
这是我尝试过的
public async Task<BaseDTO> InsertString(MyObject insertParameters)
{
try
{
using (var _client = new HttpClient())
{
_client.BaseAddress = new Uri(baseServiceUri);
_client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
HttpContent insertHttpcontent = new StringContent(JsonConvert.SerializeObject(insertObject));
var response = await _client.PostAsync(new Uri(baseAccessPoint, UriKind.Relative), insertHttpcontent);
//Throws exception when its invalid
//response.EnsureSuccessStatusCode();
var responseResult = await response.Content.ReadAsStringAsync();
return JsonConvert.DeserializeObject<BaseDTO>(responseResult, new JsonSerializerSettings()
{
NullValueHandling = NullValueHandling.Ignore,
Error = JsonDeserializeErrorHandler,
});
}
}
catch (Exception ex)
{
throw;
}
}
如果登录凭据为真,则服务将返回登录信息详细信息,否则它不会提供任何信息,只是状态,消息和代码。
问题是 Json Deseralizer 总是尝试将所有内容去血清化,即使试图设置忽略空值,但似乎不起作用。由于我的服务不返回 null,因此它不会提供对象本身。目前我使用 JsonDeserializeErrorHandler 将 errorhandle 属性设置为 true。我也参考了这个
Json结果 当成功时
{"status":"success","msg":"Welcome!!","code":"","data":{"session_token":"bdadee2cb7597fbb5ceed550ca389440","firsname":"test1","lastname":"test2"}}}}
错误时的 Json结果
{"status":"warning","msg":"Incorrect Username or MPIN","code":"","data":[]}
如何更优雅地克服这种情况
#region DeserializeErrorHandling
private void JsonDeserializeErrorHandler(object sender, Newtonsoft.Json.Serialization.ErrorEventArgs e)
{
//var currentError = e.ErrorContext.Error.Message;
e.ErrorContext.Handled = true;
}
#endregion
你的问题是,在一种情况下,你会得到一个对象{"session_token":"12", ...}
,而在另一种情况下,data
属性[]
一个空数组。空数组不为空。这意味着不能使用相同的类型来反序列化此类 JSON。
我的建议是使用 dynamic
for data
属性,然后解析此值:
[DataContract]
public class BaseDTO
{
// Rest of the properties
[DataMember]
public dynamic data { get; set; }
public LoginDTO LoginInfo
{
get
{
var jObjectData = data as JObject;
if (jObjectData == null)
{
return null;
}
try
{
return jObjectData.ToObject<LoginDTO>();
}
catch
{
return null;
}
}
}
}
您可以在LoginInfo
属性中使用更多逻辑。例如,您可以根据状态等来解析它。
注意:您的成功 JSON 无效,我想这只是一个复制/粘贴问题。