SAPUI5 (35) - OData Model 连接后端 SAP 系统 (中)

2024-02-05 13:48

本文主要是介绍SAPUI5 (35) - OData Model 连接后端 SAP 系统 (中),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

完成上一篇的配置,现在我们可以在 SAP 系统中创建基于 SAP Netweaver Gateway 的 OData Service。本篇主要是介绍在 SAP 系统中创建 OData service 的过程,为后续在 OpenUI5 中通过 OData Model 使用 SAP 系统提供的 OData 数据服务。SAP OData service 本身包含很多知识点,也需要系统学习。

本次要实现的功能:创建数据库表 zemployee,并基于 SAP Netweaver OData Service, 实现对 zemployee 的增删改查。

1. 创建 zemployee 数据库表

使用事务码 SE11 创建 zemployee 表。因为本文主要介绍 OData service 创建的过程,所以并不打算详细说明创建表的细节。为了足够简单, zemployee 表只包含 empid, empname, empaddr (employee address) 三个字段。

2. 创建基于 Netweaver Gateway 的 OData Service

2.1 创建 Gateway service project

通过事务码 SEGW,进入下面的界面:

点击 Create Project 按钮,创建一个 Gateway service project, 将 project 命名为 zempprj。点击 「Local Object」按钮,zempprj 项目创建成功:


本节动图:

我们可以看到,Gateway service 分为四个部分 (左边的 panel):

  • Data Model: 数据模型,主要包括 Entity type,( 比如说 product entity,customer entity 等),Entity set (Entity 的集合,多笔数据) 和 Association (Entity 之间的关联)
  • Service Implementation: Entity set 的 CRUD 实现

  • Runtime Artifacts: 基于 Entity set 的代码框架,包括数据模型 (Data model),数据提供者 (Data provider)

  • Service maintenance:注册服务,测试服务。

2.2 创建 Data Model

1) 创建 Entity

选中 Data Model,右键,Import -> DDIC Structure,表示从 DDIC 中导入结构作为 Entity:

将 Entity type 命名为 Employee, 字段来自 DDIC 的 zemployee 表:

选中 zemployee 表的所有字段,点击 Next 按钮:

系统进入如下界面。在这个界面中,定义 Employee 这个 entity 的字段属性。将 mandt 和 empid 定义为 primary key,并将 Name 的名称规范为首字母大写。

属性定义完成后,左边的 panel 中, Properties 下面可以看到主键和属性:


本节动图:

2) 创建 Entity set

选中左边 Panel 的 Entity Set,右键,Create。将 Entity set 命名为 EmployeeCollection, Entity type 为刚刚创建的 Employee

定义 EmployeeCollection 可以进行 CRUD:

本节动图:

2.3 Generate Runtime Objects

选中左边 Panel 的 Runtime Artifacts,点击 Generate Runtime Objects 按钮,系统进入下面的界面:

保持所有默认不变,点击 Continue 按钮。系统生成 Runtime Objects。

2.4 服务注册

前面我们在 SAP 系统中创建了 Gateway service 的别名,我们可以看到,这个别名出现在 Service maintenance 下面。双击可以进入下面的界面。

此时, Registration status 是没有状态的,点击 Register 按钮,系统弹出对话框:

选择 Sytem Alias 为 local,进入下面的界面

确认,完成系统注册。本节动图:

2.5 测试 OData service

尽管我们还没有编写 OData service 的实现代码,但已经可以通过 Browser 或者 SAP Gateway Client 进行测试了。双击左边 Panel Service maintenance 下的 localgateway,点击右边出现的 Maintain 按钮,进入下面的界面:

我们可以通过点击左下角的 Call Browser 或者 SAP Gateway Client 按钮进行测试。当点击 SAP Gateway Client 按钮的时候,界面如下:

后面我们会多次进入到这个界面,进行 CRUD 的测试。

利用 Browser 来进行测试,则有可能碰到一些问题。在这里介绍两种极有可能的情况及解决方法:

一是点击 Call Browser 按钮,系统显示 host name 或 port 没有配置好,这个时候,使用事务码 SMICM,然后通过菜单 Goto -> Services,看看主机和端口是否配置好,是否启用。

另外,还要注意域名解析,如果服务器没有在 Internet 上公开,这个 host name 不能通过 Internet 网进行访问,则需要设置本机的 hosts 文件,让本机指向这个域名。Windows 10 中 hosts 文件的位置在 C:\Windows\System32\drivers\etc 文件夹中。

2.6 服务实现 (Service maintenance)

服务实现是指提供 CRUD 的具体实现,因为读取数据的时候,存在 Entity 和 EntitySet,SAP 一般把读取 Entity 叫做 Read,把读取 EntitySet 叫做 Query。在 SEGW 界面中 展开 Service Implementation:

我们需要编写具体的代码,这样外部才能实现对 SAP 数据的增删改查。首先我们来看看 GetEntitySet 方法的编写过程。

Query

选中 GetEntitySet (Query),右键,Go to ABAP Workbench。系统提示:

点击「确认」按钮,进入下面的界面:

找到 EMPLOYEECOLLECTI_GET_ENTITYSET,右键,选择 Redefine,改写这个方法。其它的方法创建过程类似,不再重复说明。

改写后 employeecollecti_get_entityset 方法代码如下:

  METHOD employeecollecti_get_entityset.SELECT * FROM zemployeeINTO CORRESPONDING FIELDS OF TABLE et_entityset.ENDMETHOD.

et_entityset 是代码框架预设的方法参数,通过追踪,我们知道,它是基于 zemployee 的内表类型。

测试:

在 SAP Gateway Client 界面中:

  • HTTP Method: GET
  • Request URL: /sap/opu/odata/sap/ZEMPPRJ_SRV/EmployeeCollection?$format=json

系统返回的结果:

我们总可以从 SEGW 进入服务维护和 Gateway client 界面。也可以通过另外的事务码:

  • Service maintain: /IWFND/MAINT_SERVICE。这两个事务码比较怪,不通过/o 系统提示错误。所以应该输入 /O/IWFND/MAINT_SERVICE
  • SAP Gateway client: /o/iwfnd/gw_client
Read

实现 GetEntity (Read) 方法:

  METHOD employeecollecti_get_entity.DATA: ls_key_tab  TYPE /iwbep/s_mgw_name_value_pair,l_empid     TYPE zemployee-empid,ls_employee TYPE zemployee.READ TABLE it_key_tab WITH KEY name = 'EmpId' INTO ls_key_tab.l_empid = ls_key_tab-value.SELECT SINGLE * FROM zemployee INTO er_entity WHERE empid = l_empid.ENDMETHOD.

SAP Gateway Client 测试:

  • HTTP Method: GET

  • Request URL: /sap/opu/odata/sap/ZEMPPRJ_SRV/EmployeeCollection(Mandt='100',EmpId='1')?$format=json

  • Response:

{"d" : {"__metadata" : {"id" : "http://dph01.ourdomain:8180/sap/opu/odata/sap/ZEMPPRJ_SRV/EmployeeCollection(Mandt='100',EmpId='1')","uri" : "http://dph01.ourdomain:8180/sap/opu/odata/sap/ZEMPPRJ_SRV/EmployeeCollection(Mandt='100',EmpId='1')","type" : "ZEMPPRJ_SRV.Employee"},"Mandt" : "100","EmpId" : "1","EmpName" : "Stone","EmpAddr" : "Wuhan"}
}
Create

实现 Create 方法

  METHOD employeecollecti_create_entity.DATA: ls_employee TYPE zemployee." Get requested data from inputio_data_provider->read_entry_data( IMPORTING es_data = er_entity ).MOVE-CORRESPONDING er_entity TO ls_employee.INSERT zemployee FROM ls_employee.ENDMETHOD.

SAP Gateway Client 测试:

因为 Create 操作需要数据,我们可以先用 GET 方法得到一笔数据,更改后再用 POST 方法进行提交。操作步骤如下:

点击 「Use as request」,将获取的数据进行更改后提交:

返回的状态码为 201 则表示成功。

Update

实现 Update 方法:

  method EMPLOYEECOLLECTI_UPDATE_ENTITY.DATA: ls_employee TYPE zemployee." Get requested dataio_data_provider->read_entry_data( IMPORTING es_data = er_entity ).MOVE-CORRESPONDING er_entity TO ls_employee.MODIFY zemployee FROM ls_employee.endmethod.

Update 的测试使用 PUT 方法:

  • HTTP Method: PUT
  • Request URI: /sap/opu/odata/sap/ZEMPPRJ_SRV/EmployeeCollection(Mandt='100',EmpId='3')
Delete

实现 Delete 方法:

  METHOD employeecollecti_delete_entity.DATA: ls_key_tab  TYPE /iwbep/s_mgw_name_value_pair,l_empid     TYPE zemployee-empid,ls_employee TYPE zemployee.READ TABLE it_key_tab WITH KEY name = 'EmpId' INTO ls_key_tab.l_empid = ls_key_tab-value.DELETE FROM zemployee  WHERE empid = l_empid.ENDMETHOD.

测试比较简单,不再赘述。

这篇关于SAPUI5 (35) - OData Model 连接后端 SAP 系统 (中)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/681103

相关文章

linux系统中java的cacerts的优先级详解

《linux系统中java的cacerts的优先级详解》文章讲解了Java信任库(cacerts)的优先级与管理方式,指出JDK自带的cacerts默认优先级更高,系统级cacerts需手动同步或显式... 目录Java 默认使用哪个?如何检查当前使用的信任库?简要了解Java的信任库总结了解 Java 信

Oracle数据库在windows系统上重启步骤

《Oracle数据库在windows系统上重启步骤》有时候在服务中重启了oracle之后,数据库并不能正常访问,下面:本文主要介绍Oracle数据库在windows系统上重启的相关资料,文中通过代... oracle数据库在Windows上重启的方法我这里是使用oracle自带的sqlplus工具实现的方

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Mac电脑如何通过 IntelliJ IDEA 远程连接 MySQL

《Mac电脑如何通过IntelliJIDEA远程连接MySQL》本文详解Mac通过IntelliJIDEA远程连接MySQL的步骤,本文通过图文并茂的形式给大家介绍的非常详细,感兴趣的朋友跟... 目录MAC电脑通过 IntelliJ IDEA 远程连接 mysql 的详细教程一、前缀条件确认二、打开 ID

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

python连接sqlite3简单用法完整例子

《python连接sqlite3简单用法完整例子》SQLite3是一个内置的Python模块,可以通过Python的标准库轻松地使用,无需进行额外安装和配置,:本文主要介绍python连接sqli... 目录1. 连接到数据库2. 创建游标对象3. 创建表4. 插入数据5. 查询数据6. 更新数据7. 删除

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详