SAP RESTful架构和OData协议

embedded/2024/12/22 14:31:01/

一、RESTful架构

       RESTful 架构(Representational State Transfer)是一种软件架构风格,专门用于构建基于网络的分布式系统,尤其是在 Web 服务中。它通过利用 HTTP 协议和一组简单的操作(如 GET、POST、PUT、DELETE)来进行通信,以实现客户端和服务器之间的交互。RESTful 架构强调无状态、资源导向和统一接口等原则,广泛应用于现代 Web 服务和 API 设计中。

1、关键特点

a、无状态

        每个请求都是独立的,服务器不会在请求之间保存任何状态信息每个请求都必须包含完成该请求所需的所有信息(如认证信息、数据等)。这使得 RESTful 服务具有良好的可伸缩性,因为服务器不需要管理会话状态。请求头的信息必须全面。

b、客户端-服务器架构

        客户端和服务器是分离的,客户端负责用户界面和交互,服务器负责数据存储和业务逻辑处理。二者通过网络通信,互不依赖,因此可以独立演化和优化。

c、统一接口

        RESTful 系统遵循统一的接口规则,使得客户端和服务器的交互变得简洁。通常,RESTful API 使用标准的 HTTP 动作(如 GET、POST、PUT、DELETE)来访问资源。

        GET:获取资源

        POST:创建新资源

        PUT:更新现有资源

        DELETE:删除资源

d、资源

        在 RESTful 架构中,资源是系统中的任何可以被表示和操作的对象,通常以 URL(统一资源定位符)来标识。资源可以是数据(如用户信息、商品)或功能(如计算)。每个资源都有一个唯一的 URI(统一资源标识符)

e、分层系统

        RESTful 架构支持分层系统,即服务器和客户端之间可以存在多个中间层(如负载均衡器、缓存服务器、网关等)。这些中间层能够透明地处理请求和响应,但对客户端和服务器是透明的,不会影响系统的整体功能。

2、RESTful架构优点

a、简单

        RESTful 设计理念简单,基于 HTTP 协议的标准操作,使得客户端和服务器的通信非常直观。开发和维护相对容易。

b、灵活

        由于 REST 是资源导向的,客户端和服务器能够独立进化,修改一方的实现不会影响到另一方。客户端只要保留调用格式,服务器只要进行实现,互不影响。

c、高效

        RESTful 服务通常使用 JSON 或 XML 等轻量级数据格式,请求头包含所有的信息,这使得请求和响应较为简洁且高效,适合于移动设备等带宽有限的环境。

d、可扩展

        无状态的设计意味着服务器不需要存储任何会话信息,这为系统提供了更好的可扩展性。负载均衡和分布式系统能够很容易地实现。

e、标准化

        RESTful API 遵循 HTTP 标准,支持广泛的工具和库(如浏览器、代理服务器、缓存等),提高了与其他系统的兼容性。

3、常见使用RESTful的框架

a、SpringBoot(Java)

        Spring Boot 提供了非常强大的 REST 支持,通过 @RestController@RequestMapping 等注解来简化 RESTful API 的构建过程。

b、Django Rest Framework (Python)
c、Laravel (PHP)

4、与其他架构的对比

5、SAP RESTful

a、ABAP Restful Client ABAP作为Client端,连接外部系统的Restful服务

        创建一个类,实现类中的方法来进行连接服务器、请求服务、对于响应的数据进行处理等。

b、ABAP Restful Server ABAP作为Server端,对外提供Restful服务

        用下面介绍的方法,将自己在系统里面创建Gateway Service,往往遵从OData协议,支持 CRUD 操作(CREATE、READ、UPDATE、DELETE),这些服务能够通过标准 HTTP 方法(GET, POST, PUT, DELETE)与外部客户端进行交互。满足我们的需求。

二、OData协议

        OData(Open Data Protocol) 是一种基于 REST 架构的 Web 协议,主要用于查询和操作数据。它定义了一个统一的标准,使得不同系统、平台和应用程序能够通过简单的 HTTP 协议进行数据访问和操作。OData 的主要目标是简化数据访问过程,并提供灵活、标准化的数据接口,以支持数据的查询、过滤、排序、分页、更新等功能。

SAP中,我们可以创建Gateway Service。

1、使用事务码SEGW创建Gateway Service

a、点击右上角创建按钮,输入项目名称、描述,选择包,点击确认。

b、创建成功后,自动生成了如图中的数据,点击生成运行时对象按钮。

上传工作台请求,出现如图中所示提示框。系统自动生成了一些类,类中有对属性和方法的定义。点击确认即可。

Model Provider Class规定了当前创建的Gateway Service中包含哪些内容,如数据的定义、一些方法的定义。其中 *_MPC是*_MPC_EXT的父类。一般无特殊要求不对这两个类进行修改。

Data Provider Class包含了CRUD方法具体的实现。其中 *_DPC是*_DPC_EXT的父类。我们一般就只在*_DPC_EXT中对方法进行实现,一般只对他进行修改。

确认之后可以看到系统自动生成了一些类、服务等。

c、创建实体。

数据模型→Entity Type→创建。这里的数据模型还可以依据其他的东西(如搜索帮助、结构体)自动创建,可以自己尝试。

弹出框输入实体的名称,若需要该实体的集合,勾选下面的选项,名称是自动生成的。 点击确认。

d、对创建的实体的类型进行定义。双击图中标注的实体名称,在ABAP Structure中填入表名或者结构体名(全局定义的),跟Name进行关联。

e、然后点击左侧Properties,按照图中步骤,增加字段,要在ABAP Field处跟数据库中的字段进行绑定(跟数据库建立联系在上一步就已经进行了,这里点击ABAP Field搜索帮助出来的都是数据库的字段)。这里的Is Key很关键,我们后续取单条数据的时候就是通过标注了 Is Key的这个字段来取的。

字段名区分大小写,采用驼峰命名。

所有增加的字段:

f、在左边选中*_DPC_EXT右键选中Go to ABAP Workbench可前往编辑页面(我这里不可以。所以只能自己去找)。

可以看到父类信息。

在方法处我们可以看到一些已经定义的方法,但是这里还没有进行方法的实现。 

g、实现类中的方法。

这里我们先实现获取实体集合的方法。

查看方法的参数信息。可以看到很多参数,其中Returning Data是ET_ENTITYSET,我们应该将要返回的数据放到这个参数中。

在修改模式下,选中类,点击重定义方法按钮。

 实现,放在ET_ENTITYSET中:

再实现获取单条数据的方法:
它的参数: 

可以看到有个IT_KEY_TAB的参数,它是放参数KEY的键值对,里面有 NAME 和 VALUE两个字段(可通过调试来看里面的样子)。其中因为我在定义参数的时候只在stuid的Is Key处打了勾所以我的IT_KEY_TAB中的NAME只会有一个值就是 StuID。

它的Returning data是er_entity。

具体的实现如下: 

2、通过事务码/N/IWFND/MAINT_SERVICE创建服务

a、首先要添加服务

b、输入系统别名,点击获取服务,找到自己的技术服务名称(系统之前自动生成的),点击添加所选服务。

 弹出框这里的技术服务名称记一下。点击确认。

c、返回之后就可以看到自己的服务了,前面的没问题但还是看不到的话刷新一下。 选中自己的服务,点击Sap Gateway客户端。

 点击执行。

d、这个页面相当于POSTMAN这种测试软件。通过接口访问我们的方法。权限够的话,在右下角空白的地方会显示XML,但是博主系统权限不够,这里看不到信息。 

 e、若对于这个服务不太清楚,我们删除后面参数内容,点击Add URI Option选择metadata元数据。可以在Entity标签里面看到我们的实体。

 f、用别人的图举例。若我们只实现了实体集合方法的话。可以看到取每个数据时候的id标签。是怎么传StuId的。

若此时我们没有维护取单个数据的方法。XML显示如下,提示我们方法STUDENT_GET_ENTUTY还未实现,此时我们就去对应的类*_DPC_EXT中实现对应的方法即可。

g、若要删除自己的服务。选中后,先要移除系统别名,再删除服务。

注:

我们这里相当于编写后端代码,也可以用PostMan进行测试。前端部分需要进行SAP Fiori的学习。

可以去了解CDS View的有关内容与这里的内容紧密联系。

三、总结

        在SAP中,RESTful 是一种基于HTTP的架构风格,而 OData 是一种基于REST的协议,用于创建和使用Web服务。SAP通过 Gateway服务 提供OData服务,使得前端应用(如SAP Fiori)能够与后端系统进行数据交互。

        OData支持标准的CRUD操作(创建、读取、更新、删除),并通过HTTP方法(GET、POST、PUT、DELETE)进行实现。它使得SAP系统与外部应用之间的数据交换更加简单和标准化。        


http://www.ppmy.cn/embedded/147848.html

相关文章

堆【Lecode_HOT100】

文章目录 1.数组中的第K个最大元素No.2152.前K个高频元素347 1.数组中的第K个最大元素No.215 方法一:NlogN不能满足时间复杂度的要求 public int findKthLargest(int[] nums, int k) {Arrays.sort(nums);return nums[nums.length-k];}方法二&…

DePIN潜力项目Spheron解读:激活闲置硬件,赋能Web3与AI

DePIN赛道作为今年加密资本关注的热点之一,不仅吸引了大量资金涌入,还凭借其灵活的资源调配、高效的运作方式和可靠的安全性能,逐渐渗透到多个领域和项目中。例如,Helium的无线网络协议、IoTeX的去中心化物联网、IO NET的去中心化…

线程和进程、作业的区别

线程和进程、作业的区别 作业(任务)有多个进程,进程有多个线程 进程(Process): 进程是程序的一次执行过程,是操作系统进行资源分配和调度的基本单位。 每个进程都有独立的内存空间&#xff0c…

编辑, 抽成组件

问题 错误思路: 1 dept不能修改, 用watch监听一下:赋值给新的变量进行修改, 问题: currentDept 发生改变, depth也发生了改变,因为是浅拷贝, 用了json.pase(json.stringify(value…

弹性裸金属服务器(神龙):助力企业腾飞的云计算“黑科技”

在云计算飞速发展的今天,企业对于计算资源的需求早已不再满足于简单的“够用”,而是追求极致的性能、灵活的伸缩和数据安全的保障。那么,问题来了:如何在性能与弹性之间取得完美的平衡? 答案就是——阿里云弹性裸金属…

Oracle/MySQL 到 OceanBase 数据库迁移的关键问题与解决方案

目录 一. 什么是 OceanBase 数据库? 二. OceanBase 数据库的应用场景 三. Oracle 数据迁移到 OceanBase 的经典案例 四. MySQL 数据迁移到 OceanBase 的经典案例 五. OceanBase 的优势与挑战 六. 迁移中的重点问题及解决方案 七. 总结 OceanBase 数据库技术分…

3D Gaussian Splatting for Real-Time Radiance Field Rendering-简洁版

1. 研究背景与问题 传统的3D场景表示方法,如网格和点云,适合GPU加速的光栅化操作,但缺乏灵活性。而基于神经辐射场(NeRF)的表示方式,尽管质量高,但需要高成本的训练和渲染时间。此外&#xff0…

基于Spring Boot的阿坝州旅游系统

一、系统背景与目的 随着旅游业的快速发展和互联网技术的不断进步,越来越多的游客开始通过网络平台来查询旅游信息、预订旅游产品。为了满足游客对阿坝州旅游信息的需求,提升阿坝州旅游业的整体服务水平,基于Spring Boot技术框架开发了一款阿…