最近要做一个以SAP为数据中心的项目,涉及到大量的外部系统交互。所以在这里记录一下SAP Web Services 相关的技术点。方便后续回顾和使用。
SAP Web Services 发布
一、Web Service介绍
Web Service就是一个应用程序,它向外界暴露出一个能够通过Web调用的API。Web Service是一种基于Web的中间件技术。用户通过把应用程序的一部分包装成Web服务的形式,将自己的应用程序功能提供给别人,实现应用程序之间的接口。webservice可用于多个系统和SAP系统之间的传输,比较灵活。
根据外部系统提供的webservice的wsdl地址,在SAP系统创建webservice consumer时候输入该URL。使用SOAMANAGER创建逻辑端口,封装函数,在函数里指定端口,并调用类的方法,反之,创建webservice provider,生成wsdl供外部调用。
以上内容摘自ABAP接口创建。
二、创建外部调用的RFC
1.创建Function Group
如果你有可以使用的Function Group则可以跳过。
(1)使用TCODE SE80
data:image/s3,"s3://crabby-images/e3d55/e3d55eebf2950dcf173063169204a94f1e7a754a" alt="1.创建Function Group"
(2)填写Function Group的属性
data:image/s3,"s3://crabby-images/b4051/b4051365347f3208b48a78230336a9964290cfdd" alt="2.Function Group属性填写"
填写完上面的属性设置后,点击下方的按钮就创建好了一个Function Group。但是此时需要打开该Function Group的Include文件夹进行激活。因为创建好的Function Group的TOP Include是未激活状态。
data:image/s3,"s3://crabby-images/1f86b/1f86b72e9c903a71d76b1fba292f7d8b2e806590" alt="3.激活Function Group"
激活之后就可以继续下面的操作了。
2.使用TCODE SE37 创建RFC
data:image/s3,"s3://crabby-images/98994/9899424e84e881189af5b227cfe05eb1d4674ede" alt="4.创建远程调用的RFC"
data:image/s3,"s3://crabby-images/b1316/b13164ab0d124f409c57a019e843ff34daf711a0" alt="5.RFC绑定Function Group"
3.设置参数并编写Source Code
(1)输入参数
切记要勾选Pass By Value按钮,远程调用的RFC均需要勾选这个属性。
data:image/s3,"s3://crabby-images/15dfd/15dfd15e51a711682f3ce36051a48f7c65539393" alt="6.RFC 输入参数设置"
(2)输出参数
需要勾选Pass By Value按钮。
data:image/s3,"s3://crabby-images/6652d/6652d54437c77d18dd47622939692694fc83e730" alt="7.RFC 输出参数设置"
(3)Source Code
1 | FUNCTION YFM_SERVICE_TEST. |
4.设置远程RFC属性
data:image/s3,"s3://crabby-images/0ff97/0ff975f6ca4f950371cb984e05cfebfb6c897016" alt="8.远程RFC 属性设置"
三、创建Web Service
1.使用创建好的RFC创建
此处简略介绍一下这种方式,这种方式很快也很便捷。但是这次为了能 详细记录,所以主要介绍下面的通过Package的方式创建Web Service。
使用RFC直接创建。Web Service的路径如下:Utilities->More Utilities->Create Web Service->From the Function Module。
data:image/s3,"s3://crabby-images/89e27/89e2737755f74d887322c90bc9e642790bc86df5" alt="9.通过RFC直接创建Web Service"
通过这种方式可以直接跳转到下面通过Package创建的第四项填写服务名称与描述。
2.通过Package创建
(1)通过TCODE SE80 打开Package
data:image/s3,"s3://crabby-images/fd594/fd5947973448e234a640182e55668da10450033a" alt="10. 通过Package创建 SE80"
(2)选择Service Type
data:image/s3,"s3://crabby-images/51690/516907f499a98efc83fa7150ae08aba5338f7be0" alt="11.选择Service 类型"
上面选择项的翻译如下:
- Data Type:数据类型
- Message Type:Message 类型
- Datatype Enhancement:数据类型增强
- Fault Message:故障信息
- Service Consumer:服务使用者
- RFC Consumer:RFC使用者
- Service Provider:服务提供者
- Event Provider:事件提供者
- Service Variant:服务变式
- Consumer Mapping:使用者映射
- Operation Mapping:业务映射
- Processing Type Domain:处理类型域
- **Integration Scenario Def.**:集成场景描述
- Semantic Contract:
- Contract:合同
- Contract Implementation:合同执行
- Consumer Factory:使用者工厂
- Service Group:服务组
(3)服务提供类型
data:image/s3,"s3://crabby-images/8acaa/8acaa5c96974d1a828e9719847d80097cc3ebeb6" alt="12.服务提供类型"
选项意思如下:
- Backend:后端
- Enterprise Service Repository:企业服务存储库
- **Existing ABAP Object(Inside Out)**:现有ABAP对象(由内而外)
- External WSDL/Schema:外部WSDL/架构
(4)填写服务名称与描述
data:image/s3,"s3://crabby-images/d4893/d4893eced39ffa381eb4043bac44841eaea440b2" alt="13.服务名称与描述"
本次填写的服务名称与Function名称一致。
(5)选择端点类型
data:image/s3,"s3://crabby-images/abdd9/abdd9f34a9621ee14dec7559055dac81ed6cb7c4" alt="14.端点类型"
因为这一次是对远程RFC的Web Service,所以选择第二项Function Module。
(6)填写Function Module名称
data:image/s3,"s3://crabby-images/fcf12/fcf129eb6c319d5c34d347cd4deb0b4027dffff0" alt="15.填写Function Module名称"
(7)配置服务
data:image/s3,"s3://crabby-images/7ea68/7ea6804f68d015e8121bd2c111d57152c0231bed" alt="16.配置服务"
功能描述:
- No Authentication and No Transport Guarantee:无身份验证,无传输保证
- Authentication with Certificates and Transport Guarantee:证书认证和运输保证
- Authentication with User and Password,No Transport Guarantee:使用用户和密码进行身份验证,无传输保证
- Authentication with User and Password and Transport Guarantee:用户和密码身份验证及传输保证
此处选择不同的功能在发布时需要填写不同的校验方式,因为是本地的练习内容,所以选择图示内容即可。
(8)选择Package
data:image/s3,"s3://crabby-images/f12e2/f12e297ac54b30d3b82eeca3b948eac7ed77ab57" alt="17.选择Package"
此处选择存放Web Service的Package,如果选择的不是本地对象则还需要填写请求号。
(9)完成创建
data:image/s3,"s3://crabby-images/6fad0/6fad0ae24efcafadeeb1b175a8a09b5b26155b66" alt="18.完成Web Service的创建"
(10)激活Web Service
data:image/s3,"s3://crabby-images/0f3a2/0f3a255f2bfda6a657203b929278a5d10318aed0" alt="19.激活Web Service"
进行完上面的操作之后,Function Module的Web Service就创建完成了。之后就是Web Service的发布。
四、发布Web Service
1.事务码 SOAMANAGER
发布Web Service的事务码是SOAMANAGER。进入后的界面如下:
data:image/s3,"s3://crabby-images/19f31/19f315f1f86d77323e7bcd3a635861f8d547405e" alt="20.TCODE 界面"
选择图中选中的Web Service configuration。
2.查找Web Service
data:image/s3,"s3://crabby-images/50881/508817ce6b1ea5036dd4aa3cce7ad09e5776c1ff" alt="21.查找Web Service服务"
在Object Name搜索栏搜索Web Service的名称,可以使用模糊查询的方式。查询到的结果会展示在下方,在下方选择需要发布的Web Service然后单击进入创建发布界面。
3.发布管理界面
data:image/s3,"s3://crabby-images/720ec/720ecfabb01516cf191549a188e52bb765f61695" alt="22.创建发布界面"
如果后续还涉及变更等操作时,也同样是在这个界面进行操作。
4.创建Service
(1)服务与绑定名称
data:image/s3,"s3://crabby-images/cf197/cf197a7942b72a9d82728b084f618cb58fe5e724" alt="23.服务与绑定名称"
输入完服务与绑定名称之后点击上方的next按钮进行下一步。
(2)设置访问安全性
data:image/s3,"s3://crabby-images/15078/15078dc60503fc4b33dd2b082f8dd1c88efe7418" alt="24.设置访问权限"
根据上所选择的方式进行设置,本次勾选的下方User ID/Password是通过用户账号密码的形式访问的。如果在上面创建Web Service的配置服务时选择不同的内容,此处部分内容或许会变成不可编辑状态。
设置完成后点击Next按钮进入下一步。
(3)完成发布内容
data:image/s3,"s3://crabby-images/f589c/f589cad4b2af2a9a2705f8be097fb9b055488312" alt="25.SOAP 界面"
点击上方的Finish按钮完成Web Service的发布工作。
5.完成发布
data:image/s3,"s3://crabby-images/5dded/5ddedb6661ed3d70a84f67aad07b9babd6b2e7f6" alt="26.完成发布界面"
在上图点击图示按钮查看Service的属性。
6.WSDL URL
data:image/s3,"s3://crabby-images/8386a/8386ab40f9e4eb5a4d9263bc6c6fece853317004" alt="27.获取WSDL URL"
记录好下方的WSDL URL将其提供给外部调用SAP系统的开发人员或系统。外部系统就可以通过WSDL URL对SAP系统进行访问。
五、Web Service的测试
1.测试软件的安装
本次测试Web Service主要使用的是SoapUI。下载链接:https://www.soapui.org/downloads/soapui/
data:image/s3,"s3://crabby-images/a65d0/a65d08b659cc7ed6e670d94ae6167e9bf5cc7a13" alt="28.下载SOAP UI"
2.打开测试软件填入WSDL URL
新建SOAP 项目。
data:image/s3,"s3://crabby-images/6f600/6f600ec0fb5117f5475a8bb73df864f5a54d057f" alt="29.SOAP UI初始界面"
填入项目名称与上面发布的WSDL URL。
data:image/s3,"s3://crabby-images/49a73/49a73e65e6b91e01fca42067f992a830fd74fb3b" alt="30.绑定WSDL URL"
创建时需要填入你的SAP GUI账号与密码。
data:image/s3,"s3://crabby-images/8c711/8c711ca5f3b2ff90d2bf14f903fcea72ffcf0d47" alt="31.填写SAP GUI 账号与密码"
3.测试项目创建完成界面
data:image/s3,"s3://crabby-images/156cc/156cccbc6cca8d546df39020a8bdb8c4d481fa39" alt="32.测试前准备"
创建完成之后在左侧的列表会将创建好的项目展示出来。按照红框标记的内容在左侧的项目栏中双击Request 1打开XML形式的数据格式。如右侧所示,在左边的空白文本框中可以填写传递的参数。但是因为我们在发布Web Service时选择了通过用户名与密码的验证方式,所以需要在面设置访问用的账号密码。但是密码基本也和你的SAP GUI账号一致。
4.设置访问账号与密码
data:image/s3,"s3://crabby-images/74736/7473692a8dc01b928cfb4a95d725ce46c668d878" alt="33.新建权限对象"
选择权限类型
data:image/s3,"s3://crabby-images/117f0/117f026dd91f5801484bcdf76f5d3c0065a7b8e0" alt="34.新建权限对象2"
设置权限账号
data:image/s3,"s3://crabby-images/b96a9/b96a94f9456148d6f02bc893acc90e5c52ce9622" alt="35.新建权限对象3"
5.测试空值与有值两种情况
(1)空值测试
data:image/s3,"s3://crabby-images/5ccf8/5ccf8433f865827661dd87e8635d50f68956ac44" alt="36.空值校验返回值"
返回内容与Function的设置值一致。
data:image/s3,"s3://crabby-images/41751/41751d936af2c576cacdf0e55481f907bb29f405" alt="37.空值校验状态信息"
(3)有值测试
data:image/s3,"s3://crabby-images/fa732/fa73267b96943606ca493c7c0baf88dcd1a28720" alt="38.有值校验返回值"
运行状态信息如下
data:image/s3,"s3://crabby-images/0d7b6/0d7b66e3fb075dc8da10108e7313dd5fd319c260" alt="39.有值校验状态信息"
测试结果正确,Web Service创建与发布成功
六、接口一致性检查
当已经发布的接口修改或者增加栏位和结构时,需要重新进行一致性检查,否则WSDL URL地址不会更新。
1.Function 新增两个参数
新增一个输入参数和一个输出参数,在Source Code中添加相应的代码逻辑。然后激活Function。
data:image/s3,"s3://crabby-images/4ea3a/4ea3ac786d7f07adca39b95d32ca81db76ffb0a5" alt="40.一致性校验参数添加"
2.打开依照该Function Module创建的Web Service
使用TCODE SE80,找到Web Service。在Web Service处右键—>一致性检查(Consistency Check)—>激活。
data:image/s3,"s3://crabby-images/2a638/2a638d2415f06901a3058d7826df51b08113641e" alt="41.一致性检查 SAP GUI"
激活成功后的状态
data:image/s3,"s3://crabby-images/0d47e/0d47e49b5ba8c2a681182f4e58c98dee5726e6a2" alt="42.一致性检查激活成功"
3.重新发布Web Service
和正常发布Web Service的步骤类似,也是先使用TCODE SOAMANAGER。然后一直进入到下面的发布管理界面。
data:image/s3,"s3://crabby-images/7826f/7826fbb30ca57d4fcd46245fe848543a91c0a92e" alt="43.重新发布Web Service"
data:image/s3,"s3://crabby-images/9d897/9d89750d42aeab899c48b33603a010e5359d47dd" alt="44.重新发布成功"
这样就发布成功了,然后对重新发布前后的WSDL URL进行比较。重新发布一般不会变更WSDL URL,但是还是对照下的好。本次我的参数变更并没有修改WSDL URL。
data:image/s3,"s3://crabby-images/f7a8f/f7a8f773e40a8dee3d357608293d892c46b218e2" alt="45.WSDL 变更"
重新使用SOAP UI进行测试,发现修改成功。
data:image/s3,"s3://crabby-images/5bc6e/5bc6edfe574c955424c263ea8ba51c08932179ce" alt="46.重新发布变更SOAP UI"