如何对odata端点执行搜索操作

时间:2017-10-09 18:54:24

标签: .net json asp.net-web-api odata dynamics-crm-2016

CRM 2016公开了odata / web api,开箱即用functionsactions

我正在尝试执行以下请求:

https://mycrmorg.com/api/data/v8.1/Search(AppointmentRequest=@request)?@request={"ServiceId":"0640dd7b-984f-e711-9425-00155dc0d345","AnchorOffset":1,"UserTimeZoneCode":1,"RecurrenceDuration":0,"RecurrenceTimeZoneCode":1,"RequiredResources":{"ResourceId":"2031105f-ec0d-e711-9417-00155d835de9"},"SearchWindowStart":"1754-01-01T00:00:00Z","SearchWindowEnd":"9999-12-30T23:59:59Z","SearchRecurrenceStart":null,"Duration":1,"Constraints":[],"Objectives":[],"NumberOfResults":1,"Sites":[]}

更漂亮的json版本:

{
   "ServiceId":"0640dd7b-984f-e711-9425-00155dc0d345",
   "AnchorOffset":1,
   "UserTimeZoneCode":1,
   "RecurrenceDuration":0,
   "RecurrenceTimeZoneCode":1,
   "RequiredResources":{
      "ResourceId":"2031105f-ec0d-e711-9417-00155d835de9"
   },
   "SearchWindowStart":"1754-01-01T00:00:00Z",
   "SearchWindowEnd":"9999-12-30T23:59:59Z",
   "SearchRecurrenceStart":null,
   "Duration":1,
   "Constraints":[

   ],
   "Objectives":[

   ],
   "NumberOfResults":1,
   "Sites":[

   ]
}

我得到的例外是:

    {
  "error":{
    "code":"","message":"An unexpected 'StartObject' node was found for property named 'RequiredResources' when reading from the JSON reader. A 'StartArray' node was expected.","innererror":{
      "message":"An unexpected 'StartObject' node was found for property named 'RequiredResources' when reading from the JSON reader. A 'StartArray' node was expected.","type":"Microsoft.OData.Core.ODataException","stacktrace":"   at Microsoft.OData.Core.JsonLight.ODataJsonLightPropertyAndValueDeserializer.ReadNonEntityValueImplementation(String payloadTypeName, IEdmTypeReference expectedTypeReference, DuplicatePropertyNamesChecker duplicatePropertyNamesChecker, CollectionWithoutExpectedTypeValidator collectionValidator, Boolean validateNullValue, Boolean isTopLevelPropertyValue, Boolean insideComplexValue, String propertyName, Nullable`1 isDynamicProperty)\r\n   at Microsoft.OData.Core.JsonLight.ODataJsonLightPropertyAndValueDeserializer.<>c__DisplayClass14.<ReadComplexValue>b__12(PropertyParsingResult propertyParsingResult, String propertyName)\r\n   at Microsoft.OData.Core.JsonLight.ODataJsonLightDeserializer.ProcessProperty(DuplicatePropertyNamesChecker duplicatePropertyNamesChecker, Func`2 readPropertyAnnotationValue, Action`2 handleProperty)\r\n   at Microsoft.OData.Core.JsonLight.ODataJsonLightPropertyAndValueDeserializer.ReadComplexValue(IEdmComplexTypeReference complexValueTypeReference, String payloadTypeName, SerializationTypeNameAnnotation serializationTypeNameAnnotation, DuplicatePropertyNamesChecker duplicatePropertyNamesChecker)\r\n   at Microsoft.OData.Core.JsonLight.ODataJsonLightPropertyAndValueDeserializer.ReadNonEntityValueImplementation(String payloadTypeName, IEdmTypeReference expectedTypeReference, DuplicatePropertyNamesChecker duplicatePropertyNamesChecker, CollectionWithoutExpectedTypeValidator collectionValidator, Boolean validateNullValue, Boolean isTopLevelPropertyValue, Boolean insideComplexValue, String propertyName, Nullable`1 isDynamicProperty)\r\n   at Microsoft.OData.Core.UriParser.ODataUriConversionUtils.ConvertFromComplexOrCollectionValue(String value, IEdmModel model, IEdmTypeReference typeReference)\r\n   at Microsoft.OData.Core.UriParser.ODataUriUtils.ConvertFromUriLiteral(String value, ODataVersion version, IEdmModel model, IEdmTypeReference typeReference)\r\n   at Microsoft.OData.Core.UriParser.Parsers.ParameterAliasBinder.ParseComplexOrCollectionAlias(QueryToken queryToken, IEdmTypeReference parameterType, IEdmModel model)\r\n   at Microsoft.OData.Core.UriParser.Parsers.ParameterAliasBinder.ParseAndBindParameterAliasValueExpression(BindingState bindingState, String aliasValueExpression, IEdmTypeReference parameterType)\r\n   at Microsoft.OData.Core.UriParser.Parsers.ParameterAliasBinder.BindParameterAlias(BindingState bindingState, FunctionParameterAliasToken aliasToken)\r\n   at Microsoft.OData.Core.UriParser.Parsers.MetadataBinder.Bind(QueryToken token)\r\n   at Microsoft.OData.Core.UriParser.Parsers.FunctionCallBinder.BindSegmentParameters(ODataUriParserConfiguration configuration, IEdmOperation functionOrOpertion, ICollection`1 segmentParameterTokens)\r\n   at Microsoft.OData.Core.UriParser.Parsers.ODataPathParser.TryBindingParametersAndMatchingOperationImport(String identifier, String parenthesisExpression, ODataUriParserConfiguration configuration, ICollection`1& boundParameters, IEdmOperationImport& matchingFunctionImport)\r\n   at Microsoft.OData.Core.UriParser.Parsers.ODataPathParser.TryCreateSegmentForOperationImport(String identifier, String parenthesisExpression)\r\n   at Microsoft.OData.Core.UriParser.Parsers.ODataPathParser.CreateFirstSegment(String segmentText)\r\n   at Microsoft.OData.Core.UriParser.Parsers.ODataPathParser.ParsePath(ICollection`1 segments)\r\n   at Microsoft.OData.Core.UriParser.Parsers.ODataPathFactory.BindPath(ICollection`1 segments, ODataUriParserConfiguration configuration)\r\n   at Microsoft.OData.Core.UriParser.ODataUriParser.Initialize()\r\n   at System.Web.OData.Routing.DefaultODataPathHandler.Parse(IEdmModel model, String serviceRoot, String odataPath, ODataUriResolverSetttings resolverSettings, Boolean enableUriTemplateParsing)\r\n   at System.Web.OData.Routing.DefaultODataPathHandler.Parse(IEdmModel model, String serviceRoot, String odataPath)\r\n   at Microsoft.Crm.Extensibility.OData.CrmODataPathHandler.Parse(IEdmModel model, String serviceRoot, String odataPath)"
    }
  }
}

我认为我编码RequiredResources的方式可能存在问题。 我做错了什么?如何将此请求发送到CRM?

1 个答案:

答案 0 :(得分:2)

我认为问题可能是您使用RequiredResources作为对象而不是集合,请尝试将其更改为

"RequiredResources": [{
   "ResourceId":"2031105f-ec0d-e711-9417-00155d835de9"
}],

完成JSON

{
   "ServiceId":"0640dd7b-984f-e711-9425-00155dc0d345",
   "AnchorOffset":1,
   "UserTimeZoneCode":1,
   "RecurrenceDuration":0,
   "RecurrenceTimeZoneCode":1,
   "RequiredResources": [{
      "ResourceId":"2031105f-ec0d-e711-9417-00155d835de9"
   }],
   "SearchWindowStart":"1754-01-01T00:00:00Z",
   "SearchWindowEnd":"9999-12-30T23:59:59Z",
   "SearchRecurrenceStart":null,
   "Duration":1,
   "Constraints":[

   ],
   "Objectives":[

   ],
   "NumberOfResults":1,
   "Sites":[

   ]
}
  

RequiredResources   集合(RequiredResource ComplexType)

取自

https://msdn.microsoft.com/en-us/library/mt592984.aspx

错误消息实际上告诉您解析器需要[而不是{symbol / token。