0

我正在尝试使用 Microsoft Dynamics NAV 中的 Simple.OData.Client 通过 OData Web 服务发布新的 SalesOrder 条目。

有效

        ODataClientSettings settings = new ODataClientSettings();
        settings.BaseUri = new Uri(Constants.ODataServiceEndpoint);
        settings.Credentials = new NetworkCredential(Constants.SecureUserName, Constants.SecureUserPassword);
        client = new ODataClient(settings);

        var items = await client
            .For("SalesOrder")
            .FindEntriesAsync();

不幸的是,这不起作用,我不知道为什么:

        var product = await client
                .For<SalesOrder>("SalesOrder")
                .Set(CreateDummyOrder())
                .InsertEntryAsync();

我得到这个例外:

     Exception caught : Simple.OData.Client.WebRequestException: Internal Server Error
     at Simple.OData.Client.RequestRunner.PostExecute(HttpResponseMessage responseMessage)
     at Simple.OData.Client.RequestRunner.ExecuteRequestAsync(ODataRequest request, CancellationToken cancellationToken)
     at Simple.OData.Client.ODataClient.ExecuteRequestWithResultAsync[T](ODataRequest request, CancellationToken cancellationToken, Func`2 createResult, Func`1 createEmptyResult, Func`1 createBatchResult)
     at Simple.OData.Client.ODataClient.InsertEntryAsync(FluentCommand command, Boolean resultRequired, CancellationToken cancellationToken)
     at Simple.OData.Client.BoundClient`1.InsertEntryAsync(Boolean resultRequired, CancellationToken cancellationToken)
4

1 回答 1

0

最后,我找出了问题所在。

对于要处理它的每个人,都必须使用OData V4 URL。虽然我不确定为什么该帖子无法使用 OData V3 URL。之后,您必须启用手动编号。

于 2019-02-26T19:56:52.377 回答