JsonConvert.DeserializeObject在反序列化CouchBase响应时引发异常

问题描述 投票:0回答:1

我正在尝试反序列化来自CouchBase的JSON响应。但是,反序列化引发异常。

            IQueryRequest queryRequest = QueryRequest.Create(queryString);
            queryRequest.ScanConsistency(ScanConsistency.RequestPlus);
            var queryResult = await bucket.QueryAsync<dynamic>(queryRequest);

            if (!queryResult.Success)
            {
            }

            foreach (var row in queryResult.Rows)
            {
                try
                {
                    var registrationDetails = JsonConvert.DeserializeObject<IEnumerable<RegistrationModel>>(row);
                    //var registrationDetail1 = JsonConvert.DeserializeObject<RegistrationModel>(row);
                }
                catch (Exception Ex)
                { }

            }

我得到的异常:

{Microsoft.CSharp.RuntimeBinder.RuntimeBinderException: The best overloaded method match for 'Newtonsoft.Json.JsonConvert.DeserializeObject<System.Collections.Generic.IEnumerable<MC4B_CommonInterface.RegistrationModel>>(string)' has some invalid arguments
   at CallSite.Target(Closure , CallSite , Type , Object )
   at System.Dynamic.UpdateDelegates.UpdateAndExecute2[T0,T1,TRet](CallSite site, T0 arg0, T1 arg1)
   at DataAccess.Services.RegistrationDataServices.ActivateSimpleRegistrations(ActivateRequest request) ...}

来自Couchbase的响应很简单。 RegistrationModel具有所有JsonProperty属性。

[
  {
    "acsPntDocId": "",
    "adLis": "[]",
    "adP2DNa": "CA",
     .....
    }
]

我注意到的一件事是foreach (var row in queryResult.Rows)row包含{{"acsPntDocId":"","adLis": "[]", ...}}

c# json asp.net-core json.net couchbase
1个回答
0
投票

根据您在问题结尾处发布的字符串结果,可能是row已经是JObject。根据这篇文章https://stackoverflow.com/a/44308752/579148,似乎在反序列化之前将.ToString()添加到Jobject可能会帮到您。

例如:

string rowString = row.ToString();
var registrationDetails = JsonConvert.DeserializeObject<IEnumerable<RegistrationModel>>(rowString);
© www.soinside.com 2019 - 2024. All rights reserved.