我有一个按钮,我想通过press-method将数据发布到我的SAP后端:
oCellBtnOtherchart.addContent(new sap.ui.commons.Button({
text : "Save",
press : function() {
var sServiceUrl = "/MyEntitSet('0001')";
var oModel = sap.ui.getCore().getModel();
console.log(oModel);
var oParameters = {
"email" : "a",
"lastname" : "b",
"firstname" : "c",
};
oModel.create(sServiceUrl, oParameters);
}
}));
我的问题是:
但是为什么它是405,我的服务网址错了?如何将数据正确发布到SAP后端?
SAP故障排除指南说:405方法不允许 o资源不允许在请求行中指定的方法 由Request-URI标识。响应必须包含Allow标头 包含所请求资源的有效方法列表。 - >这对我现在没有帮助,任何人都知道如何包含一个允许标题?
答案 0 :(得分:11)
因为在SO上这个主题只有很少的线程,我认为这些线程没有回答我的问题,我将分享我的发现如何通过oModels创建方法将数据传递到后端:
首先定义结果实体的类型(检查oData-Model以了解属性,例如Name和YourID):
var oEntry = {};
oEntry.YourID = "0001";
oEntry.Name = "Peter";
然后获取您的模型:
var oModel = sap.ui.getCore().getModel();
然后执行创建操作,感谢:https://sapui5.netweaver.ondemand.com/docs/api/symbols/sap.ui.model.odata.ODataModel.html
jQuery.sap.require("sap.ui.commons.MessageBox");
oModel.create('/EntitySet', oEntry, null, function(){
sap.ui.commons.MessageBox.show(
sap.ui.commons.MessageBox.alert("Success!");
);
},function(){
sap.ui.commons.MessageBox.alert("Error!");
});
方法中后端的结果" ENTITYSET_CREATE_ENTITY" -Method,您可以在其中检索YourID和名称:
DATA: ls_data TYPE ycl_class_mpc=>ts_entity.
CALL METHOD io_data_provider->read_entry_data
IMPORTING
es_data = ls_data.
WRITE ls_data-name.
WRITE ls_data-yourid.
此示例适用于单个调用,可以看到ABAP中的结果是一个结构。如果需要将多个数据集传递给后端,则应在https://openui5.hana.ondemand.com/docs/api/symbols/sap.ui.model.odata.ODataModel.html
处搜索批处理答案 1 :(得分:0)
如果您仍在寻找关于如何制作批量帖子的好博客,请查看此帖子http://scn.sap.com/community/developer-center/front-end/blog/2012/11/18/gateway-batch-calls-from-sapui5