首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过连接服务的OData批处理请求始终返回202已接受

通过连接服务的OData批处理请求始终返回202已接受
EN

Stack Overflow用户
提问于 2020-12-15 19:14:47
回答 1查看 360关注 0票数 1

我们在SAP CloudFoundry上部署了一个springboot/sap-cloud-sdk (3.34.1)应用程序。我们的应用程序连接到本地SAP Gateway for OData服务,并使用CF目标和连接服务。在大多数情况下,这工作得很好。我们最近开始对我们的SAP OData服务使用批处理请求。

针对SAP网关的本地测试表明,批处理请求得到了很好的处理。当我们发送一个应该失败的请求时,我们得到了正确的错误结果,而当我们发送一个好的请求时,它也得到了很好的处理。

但是,当我们在SAP CF上部署应用程序,并且请求通过连接服务路由时,我们总是得到一个HTTP 202 Accepted响应。无论SAP网关返回什么。如果我们在SAP网关上进行一些调试和跟踪,我们会看到预期的请求进入,还会看到来自SAP网关的预期响应。

因此,连接服务似乎无法以某种方式将响应传递回我们的应用程序。

上图显示了请求通过的组件。我们的PMD应用程序使用云sdk创建批处理请求,解析目的地,并通过连接服务将其发送到SAP网关。网关返回正确的响应,但我们从未在我们的应用程序中看到该响应。相反,我们总是得到一个202接受的响应。

-- Update 2020-12-15 16:39 --

我们正在使用OData V2。我们已经做了更多的测试,这不是连接服务。我们只关注SAP网关的响应负载。但是显然批处理响应总是包装在一个202接受的响应中。如果我们更仔细地观察,我们会得到以下响应:

代码语言:javascript
复制
HTTP/1.1 202 Accepted

content-type: multipart/mixed; boundary=6C34B07793A6EA7C8AAFC5BC339BDAEC0
content-length: 709
dataserviceversion: 2.0
cache-control: no-cache, no-store, must-revalidate
sap-perf-fesrec: 1300458.000000

--6C34B07793A6EA7C8AAFC5BC339BDAEC0
Content-Type: application/http
Content-Length: 1171
content-transfer-encoding: binary

HTTP/1.1 400 Bad Request
Content-Type: application/json;charset=utf-8
Content-Length: 1050
dataserviceversion: 1.0

{"error":{"code":"ZCU/100","message":{"lang":"nl","value":"Service 0000000003 0000000010 niet gevonden voor operatie 0410"},"innererror":{"application":{"component_id":"","service_namespace":"/SAP/","service_id":"ZCU_PE_ORDER_SRV","service_version":"0001"},"transactionid":"23F2932D54040110E005FD84A23B406E","timestamp":"20201215151501.0634490","Error_Resolution":{"SAP_Transaction":"Run transaction /IWFND/ERROR_LOG on SAP Gateway hub system (System Alias ) and search for entries with the timestamp above for more details","SAP_Note":"See SAP Note 1797736 for error analysis (https://service.sap.com/sap/support/notes/1797736)","Batch_SAP_Note":"See SAP Note 1869434 for details about working with $batch (https://service.sap.com/sap/support/notes/1869434)"},"errordetails":[{"code":"ZCU/100","message":"Service 0000000003 0000000010 niet gevonden voor operatie 0410","propertyref":"","severity":"error","target":""},{"code":"/IWBEP/CX_MGW_BUSI_EXCEPTION","message":"Fout bij wijzigen PE order.","propertyref":"","severity":"error","target":""}]}}}
--6C34B07793A6EA7C8AAFC5BC339BDAEC0--

不知何故,SAP Cloud SDK无法正确读取响应的内容。

在我们的代码中,我们用请求发送一个变更集。以下方法是我们的批处理调用的核心。batchUpdatePEOrderById执行该请求。其他方法只是准备批处理请求的帮助器。

我们期望f.get(0)会解开第一个变更集的结果,或者至少在我们的示例请求中会产生一个Try.failure(),但它总是会产生一个Try.success()。

代码语言:javascript
复制
private Either<DomainError, ExternalId> batchUpdatePEOrderById(final ExternalId id, List<ServiceChange> serviceChanges, final String jwtToken) {
    final HttpDestination sapMatrix = httpDestinationProvider.providePrincipalPropagationDestination(jwtToken);

    // See https://sap.github.io/cloud-sdk/docs/java/features/odata/use-typed-odata-v2-client-in-sap-cloud-sdk-for-java#batch-requests
    var f = prepareBatchRequest(id, serviceChanges)
            .executeRequest(sapMatrix);
    return f.get(0).toEither()
            .bimap(error -> getDomainError(id, error), result -> {
                log.warn("Updated PE-Order {} successfully: {}", id, result.getCreatedEntities());
                return id;
            });
}

private ZCUPEORDERSRVServiceBatch prepareBatchRequest(ExternalId id, List<ServiceChange> serviceChanges) {
    var batch = peOrderService.batch();
    var changeSet = batch.beginChangeSet();
    // Split service changes and add to batch operation
    var newServices = mapServiceChanges(ChangeType.ADDED, serviceChanges, id);
    var updatedServices = mapServiceChanges(ChangeType.QUANTITY_CHANGED, serviceChanges, id);
    var deletedServices = mapServiceChanges(ChangeType.DELETED, serviceChanges, id);

    if (!newServices.isEmpty()) {
        buildServiceChangeSet(changeSet, newServices, ChangeType.ADDED);
    }

    if (!updatedServices.isEmpty()) {
        buildServiceChangeSet(changeSet, updatedServices, ChangeType.QUANTITY_CHANGED);
    }

    if (!deletedServices.isEmpty()) {
        buildServiceChangeSet(changeSet, deletedServices, ChangeType.DELETED);
    }
    return changeSet.endChangeSet();
}

private void buildServiceChangeSet(ZCUPEORDERSRVServiceBatchChangeSet changeSet, final List<Dienst> services, final ChangeType changeType) {
    switch (changeType) {
        case ADDED:
            services.forEach(changeSet::createDienst);
            break;
        case QUANTITY_CHANGED:
            services.forEach(changeSet::updateDienst);
            break;
        case DELETED:
            services.forEach(changeSet::deleteDienst);
            break;
        default:
            changeSet.endChangeSet();
    }
}

你知道这里会出什么问题吗?

谢谢,

丹尼

EN

回答 1

Stack Overflow用户

发布于 2020-12-22 00:15:03

此错误已从SAP Cloud SDK 3.34.1修复。

查看相应的release notes

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65304773

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档