使用 OData 服务在 yMarketing 中创建交互 CUAN_IMPORT_SRV

Create Interactions in yMarketing with OData Service CUAN_IMPORT_SRV

我在 SAPUI5 应用程序(在 Web IDE 中)工作,它在 Hybris Marketing 中创建交互。因此我使用 OData 服务 CUAN_IMPORT_SRV。我已经用一个简单的 Postman 请求尝试过它并且工作正常。交互是在 Hybris Marketing 中创建的。

示例 JSON 上传正文如下所示(以 Call OData Service 为导向):

{
   "Id" : "",
   "Timestamp" : "/Date(1506014140593)/",
   "UserName" : "UNAME",
   "SourceSystemId" : "ANY",
   "Interactions" : [
      {
         "Key" : "",
         "CampaignId" : "",
         "CommunicationMedium" : "BUSINESS_DOCUMENT",
         "ContactId" : "005056966DBE1EE4B299CD12B99F60C4",
         "ContactIdOrigin" : "SAP_HYBRIS_MKT_IC",
         "ContentData" : "First Event",
         "ContentTitle" : "",
         "InitiativeId" : "100001622",
         "InitiativeVersion" : 0,
         "InteractionType" : "CRM_ACTIVITY",
         "IsAnonymous" : false,
         "MarketingOrchestrationId" : 0,
         "Quantifier" : 1,
         "Timestamp" : "/Date(1506014140283)/"
      }
   ]
}

数据合理与否不予讨论。现在只是一个测试用例。在我的 SAPUI5 应用程序中,我开始编写一个简单的函数来处理数据上传。我面向 this topic.

这是我的功能:

onPressScan: function() {
sap.ndc.BarcodeScanner.scan(

    function(mResult) {

        if (!mResult.cancelled) {
            // begin POST Interaction with OData
            var oModel = new sap.ui.model.odata.v2.ODataModel("https://host:port/sap/opu/odata/sap/CUAN_IMPORT_SRV/", true, "UNAME", "PASSWORD");
            oModel.setHeaders({
                "X-CSRF-Token" : "Fetch"
            });

            var jsonString = '{ "Id" : "", "Timestamp" : "/Date(1506014140591)/",  "UserName" : "UNAME", "SourceSystemId" : "ANY", "Interactions" : [ ' +
            '{ "Key" : "" , "CampaignId" : "" , "CommunicationMedium" : "BUSINESS_DOCUMENT" , "ContactId" : "005056966DBE1EE4B299CD12B99F60D4" ' +
            ', "ContactIdOrigin" : "SAP_HYBRIS_MKT_IC" , "ContentData" : "Try from Scanner App", "ContentTitle" : "Scan", "InitiativeId" : "100001622" ' +
            ', "InitiativeVersion" : 0, "InteractionType" : "CRM_ACTIVITY", "IsAnonymous" : false, "MarketingOrchestrationId" : 0, "Quantifier" : 1, "Timestamp" : "/Date(1506014140281)/" }]}';

            var json = JSON.parse(jsonString);

            // get X-CSRF-Token for POST request
            oModel.read("/$metadata", null, null, true, function(oData, oResponse) {

            var xcsrfToken = oResponse.headers["x-csrf-token"];

            oModel.setHeaders({
                "X-CSRF-Token" : xcsrfToken,
                "Content-Type" : "application/json"
            });

            // POST interaction to yMarketing
            oModel.create("/ImportHeaders", json, null, function() {
                alert("Create successful");
            }, function(){
                alert("Create failed");
            });
        }, function() {
            alert("Read failed");
        });
    }}, function(Error) {
        sap.m.MessageBox.error("Scanning failed due to following error: " + Error, {
            title: "Error while scanning"                                     
        });
    }
);

}

当我尝试应用程序时出现以下错误:

在声明 OData 模型时,我使用正确的系统 UNAME 和 PASSWORD 进行读写。我做错了什么?

非常感谢任何提示!

单击 Chrome 图标 > 选项 > 在目标路径后面添加:

--disable-web-security --user-data-dir