java - SFSF OData 调用:无法将响应转换为 ODataFeed:发生“EdmSimpleTypeException”
问题描述
根据问题中的问题: Generate VDM for SFSF using Java in SAP Cloud SDK: Generated URI is wrong
我使用 Maven 插件和 SAP Cloud SDK for Java 从 SFSF的元数据文件生成了一个虚拟数据模型。
生成器正常工作,但是生成的 URI 不是 SFSF 所期望的:
生成的 URI:/odata/v2/SFODataSet
预期的 URI:/odata/v2 或 /odata/v2/JobRequisition
(SFODataSet 实体不存在,SFSF 在尝试访问它时会出错)。
无论如何,我继续并将生成文件中的 DEFAULT_SERVICE_PATH 更改为/odata/v2并创建以下包含查询的 servlet:
@WebServlet("/req")
public class JobReqServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
private static final Logger logger = LoggerFactory.getLogger(JobReqServlet.class);
private final ErpHttpDestination destination = DestinationAccessor.getDestination("sfsf-sdk-dest").asHttp()
.decorate(DefaultErpHttpDestination::new);
@Override
protected void doGet(final HttpServletRequest request, final HttpServletResponse response)
throws ServletException, IOException {
try {
long id = 2126;
final JobRequisition jobReqs = new DefaultRCMJobRequisitionService()
.getJobRequisitionByKey(id)
.execute(destination);
response.getWriter().write("Done!");
} catch (final ODataException e) {
logger.error(e.getMessage(), e);
response.setStatus(HttpServletResponse.SC_INTERNAL_SERVER_ERROR);
response.getWriter().write(e.getMessage());
}
}
}
这会查询一个工作申请(id 为 2126)。没有必要添加选项.withServicePath()因为它已经改变了。
但是,在运行应用程序时,等待 10-20 秒后出现内部服务器错误。
在日志中,我可以看到以下内容:
- 目的地被正确提取
- HTTP 请求正确
- SFSF 以正确的数据响应
但是在收到数据后就出现了错误:
"com.sap.cloud.sdk.odatav2.connectivity.ODataQuery","thread":"http-nio-0.0.0.0-8080-exec-3","level":"ERROR","categories":[],"msg":"Failed to convert response into ODataFeed: An exception of type 'EdmSimpleTypeException' occurred." }
在此处的云端硬盘中查找:
- 调试日志 (SDKapplogs.txt)
- 来自 SFSF 的 JSON 响应 (response.json)
任何帮助,将不胜感激。
解决方案
用于生成 VDM 的 EDMX 文件与远程 OData 服务响应不兼容。请要求 OData 服务的维护者提供最新的元数据文件。您也可以尝试直接从http://[URL]/odata/v2/$metadata
.
我发现您附加的大约一半 JSON 示例有效负载与 API Business Hub 上发布的 EDMX 文件不兼容。
响应包含无法与元数据匹配的未知实体属性:
"departmentCode": null "locationCode": null "divisionCode": null "costCenterCode": null "instrGen": null "legalEntityCode": null "templateName": "Standard Job Requisition" "routeMap": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/routeMap"}} "motorVeh": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/motorVeh"}} "payType": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/payType"}} "requiredTravel": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/requiredTravel"}} "state": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/state"}} "jobProfile": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/jobProfile"}} "division_obj": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/division_obj"}} "legalEntity_obj": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/legalEntity_obj"}} "jobReqFwdCandidates": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/jobReqFwdCandidates"}} "status": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/status"}} "budgeted": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/budgeted"}} "jobApplications": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/jobApplications"}} "shiftSchedule": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/shiftSchedule"}} "interviewGuide": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/interviewGuide"}} "jobAnalyzerReportingData": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/jobAnalyzerReportingData"}} "assessment": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/assessment"}} "adCode": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/adCode"}} "flsa": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/flsa"}} "costCenter_obj": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/costCenter_obj"}} "filter1": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/filter1"}} "filter2": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/filter2"}} "filter3": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/filter3"}} "eeoJobCat": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/eeoJobCat"}} "location_objlist": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/location_objlist"}} "accommo": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/accommo"}} "experienceReq": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/experienceReq"}} "relocationPack": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/relocationPack"}} "rsnVacancy": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/rsnVacancy"}} "location_obj": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/location_obj"}} "competencies": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/competencies"}} "department_obj": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/department_obj"}} "PD": {"__deferred": {"uri": "https://[URL]/odata/v2/JobRequisition(2126L)/PD"}}
响应包含不允许为空的实体属性的意外空值:
"closedDateTime": null "timeToFill": null "jobReqGUId": null "overallScaleName": null "lastModifiedProxyUserId": null "positionNumber": null "age": null
不幸的是,这些错误没有得到妥善处理,并将关闭任何反序列化尝试。由于这发生在SAP Service SDK的第三方Olingo库中,我们无法修复或更改它,或提供有意义的解决方法。
您需要确保从头到尾使用正确的元数据文件。
推荐阅读
- image - 高级图像过滤器
- docker - 删除 docker 容器后如何保留日志文件?
- javascript - 将 Stryker JS 与 SVN 存储库一起使用
- valgrind - 在 fdopen 之后关闭 popen 流是否有任何问题
- c++ - 如何在同一个图表中绘制多个线系列?
- node.js - 如何使用 Viber Bot 发送消息
- java - Android Studio JNI/C++:如何为所有#include标签定义根路径?
- ansible - Ansible - 在包含时使用
- homey - 如何使用动态参数创建温馨的流程
- reactjs - 在 ReactJS 中单击外部时更新输入框