揭开SAP Fiori编程模型规范里注解的神秘面纱 - @OData.publish工作原理解析

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介: 揭开SAP Fiori编程模型规范里注解的神秘面纱 - @OData.publish工作原理解析

Jerry的前一篇文章 揭开SAP Fiori编程模型规范里注解的神秘面纱 - @ObjectModel.readOnly工作原理解析,给大家分享了@ObjectModel.readOnly这个注解对应的Fiori UI和ABAP后台的工作原理。


今天我们继续研究另一个注解@OData.publish.


在SAP官网的ABAP Programming Model for SAP Fiori的帮助文档里,在OData Annotations目录下有对这个注解的介绍:


https://help.sap.com/viewer/cc0c305d2fab47bd808adcad3ca7ee9d/1709%20000/en-US/ccdb054e4ecf4573829d4ba258cafa72.html

image.png



一旦加上了这个注解的CDS view激活时,会自动生成一个OData服务。


image.png


这个OData服务是如何自动生成的?这就是本文所要分享的内容。


假设我们对加了这个注解的CDS view激活后自动生成的OData服务的明细一无所知,从何处开始入手进行研究呢?


我创建了一个名为zjerrytest20160311的view,然后加上这个注解,激活。根据我的经验,按照SAP惯例,自动生成的OData服务的名称应该也会包含0311这个字符串。


image.png


激活之后,我试着用0311作为关键字在OData服务的注册事务码/IWFND/MAINT_SERVICE里搜索,果然搜到了对应生成的OData服务:

image.png



在Jerry之前的文章 ABAP CCDEF, CCIMP, CCMAC, CCAU, CMXXX这些东东是什么鬼 曾经提到ABAP Netweaver的注册表TADIR,按照0311进行查询,发现CDS view激活之后,除了OData服务本身,还自动生成了下列这些对象:


image.png


IWMO: SAP Gateway Business Suite Enablement对应的模型

IWSV: SAP Gateway Business Suite Enablement对应的服务

CLAS: OData服务的实现类ZCL_ZJERRYTEST20160311


做个实验,当我把OData.publish的值设置为false,再次激活,发现类型为IWMO和IWSV的对象从注册表TADIR中消失了,这再次印证了二者是注解OData.publish设置为true之后激活CDS view生成的。

image.png



那么如何研究CDS view激活时,这两个对象的自动生成逻辑呢?


使用Jerry文章 SAP错误消息调试之七种武器:让所有的错误消息都能被定位 里介绍的第六种武器,离别钩之ST05.


打开ST05跟踪模式,激活CDS view,在数据库跟踪结果里果然发现了将自动生成的对象名称插入到注册表TADIR的OPEN SQL语句。


image.png


《神雕侠侣》天竺僧去绝情谷给杨过找情花毒解药时,说过一句话:毒蛇出没之处,七步之内必有解药。

image.png



同样,在ABAP里,在插入数据库表的OPEN SQL语句之前,必定有待插入数据的生成逻辑。


点击ST05里蓝色的眼镜图标,自动跳转到OPEN SQL语句里。设置断点,激活CDS view,断点触发:


image.png


从当前的调用栈往外追溯,发现在第21个调用栈帧,正是自动生成OData服务的地方:


image.png


CL_WB_DDLS_SECOBJ_HNDLR_SINGLE->IF_DDIC_WB_DDLS_SECOBJ_HANDLER~ON_ACTIVATION


这个方法首先根据delta_state判断出需要删除,新增或者更新的对象清单,分别存储在下图12到14行三个输出参数里。


image.png


举个例子,当我在一个已经激活过后的CDS view源代码里添加@OData.publish:true的注解,然后激活,此时该注解对于的EDIT_STATE为N(New), 而其他的注解因为没有任何变化,被标记为U(Unchanged).


image.png


此处会根据EDIT_STATE的值,进入对应的分支。


image.png


EDIT_STATE值为N的分支,则执行OData服务的创建,通过CL_SADL_GTK_ODATA_SERVICE_GEN完成,后缀GEN代表Generation.


image.png


从调试器里能看出,名称为ZJERRYTEST20160311的OData服务通过create_via_exposure方法被创建。


完整的调用栈:


image.png


本文其实也是另一个具体的例子,在不了解一段逻辑(无论框架层面或者应用层面)的情况下,如何使用ST05这个工具来找到设置断点的代码位置,从而找到问题分析的突破口。


感谢阅读。


更多阅读


Jerry的通过CDS view + Smart Template 开发Fiori应用的blog合集


SAP Fiori应用的三种部署方式


Jerry的Fiori原创文章合集


SAP成都C4C小李探花:浅谈Fiori Design Guidelines


SAP Fiori + Vue = ?


Fiori Fundamentals和SAP UI5 Web Components


30分钟用Restful ABAP Programming模型开发一个支持增删改查的Fiori应用


SAP Fiori应用索引大全


介绍一种Fiori标准应用的增强方式


揭开SAP Fiori编程模型规范里注解的神秘面纱 - @ObjectModel.readOnly工作原理解析


为什么SAP GUI里的传统事务码能通过Fiori Launchpad启动并运行在浏览器里


一步步把SAP GUI的事务码配置到SAP Fiori Launchpad里


相关文章
|
Web App开发 监控 安全
使用注解 @requires 给 SAP CAP CDS 模型添加权限控制
使用注解 @requires 给 SAP CAP CDS 模型添加权限控制
|
SQL 存储 JavaScript
SAP Fiori @OData.publish 注解的工作原理解析
SAP Fiori @OData.publish 注解的工作原理解析
|
Java 数据库 数据库管理
一个实际的例子学习 SAP BTP Java 应用的 @Before 注解使用方式
一个实际的例子学习 SAP BTP Java 应用的 @Before 注解使用方式
|
XML 开发框架 数据格式
SAP UI5 应用开发教程之五十七 - 基于 OData 注解的 Smart Field 使用方法学习试读版
SAP UI5 应用开发教程之五十七 - 基于 OData 注解的 Smart Field 使用方法学习试读版
SAP UI5 应用开发教程之五十七 - 基于 OData 注解的 Smart Field 使用方法学习试读版
如何通过 ABAP 代码给 SAP OData 元数据增添注解试读版
如何通过 ABAP 代码给 SAP OData 元数据增添注解试读版
如何通过 ABAP 代码给 SAP OData 元数据增添注解试读版
|
12月前
|
前端开发 开发者
如何在 SAP Fiori Elements 应用的 manifest.json 里定义注解
如何在 SAP Fiori Elements 应用的 manifest.json 里定义注解
|
12月前
|
XML 移动开发 前端开发
SAP UI5 本地注解文件词汇表内容引用的详细讲解
SAP UI5 本地注解文件词汇表内容引用的详细讲解
|
Web App开发 数据库 开发者
SAP Fiori 注解 @ObjectModel.readOnly工作原理解析
SAP Fiori 注解 @ObjectModel.readOnly工作原理解析
|
XML 开发框架 数据格式
|
XML 存储 架构师
SAP Fiori Elements 公开课第三单元学习笔记 - OData 和注解深入讲解
SAP Fiori Elements 公开课第三单元学习笔记 - OData 和注解深入讲解
SAP Fiori Elements 公开课第三单元学习笔记 - OData 和注解深入讲解

热门文章

最新文章

下一篇
无影云桌面